Submission #735287

#TimeUsernameProblemLanguageResultExecution timeMemory
735287WaelSecret (JOI14_secret)C++14
0 / 100
477 ms9776 KiB
#include "secret.h" #include <bits/stdc++.h> using namespace std; typedef long long ll; //#define int long long #define F first #define S second //#define endl '\n' #define INT INT_MAX int const M = 1e3 + 30 , N = 3e6 , lg = 25 , mod = 1e9 + 7; int dx[] = {0 , 0 , -1 , 1 , 1 , 1 , -1 , -1}; int dy[] = {1 , -1 , 0 , 0 , 1 , -1 , 1 , -1}; int T , n , j , a[M] , Q , l , r , Size = 1024 , s[M]; long long ans[M][M]; /* inline ll Secret(int x , int y) { //cout << x << " " << y << endl; int res; res = x + y; return res; } */ void Go(int x = 1 , int lx = 1 , int rx = Size) { if(lx == rx) { ans[lx][rx] = s[lx]; return; } int mid = (lx + rx) / 2; int a = mid , b = mid + 1; ans[b][b] = s[b]; for(int i = b + 1 ; i <= rx ; ++i) ans[b][i] = Secret(ans[b][i - 1] , s[i]); ans[a][a] = s[a]; for(int i = a - 1 ; i >= lx ; --i) ans[i][a] = Secret(ans[i + 1][a] , s[i]); Go(2 * x , lx , mid); Go(2 * x + 1 , mid + 1 , rx); } int Get(int l , int r , int x = 1 , int lx = 1 , int rx = Size) { int mid = (lx + rx) / 2; if((mid >= l && mid <= r)) { int res = 0; if(mid >= l && mid + 1 <= r) res = Secret(ans[l][mid] , ans[mid + 1][r]); else if(mid == r) res = ans[l][mid]; return res; } if(l > mid) return Get(l , r , 2 * x + 1 , mid + 1 , rx); else return Get(l , r , 2 * x, lx , mid); } void Init(int sz , int ar[]) { n = sz; for(int i = 1 ; i <= n ; ++i) s[i] = ar[i - 1]; Go(); } int Query(int l , int r) { ++l , ++r; if(l == r) return s[l]; return Get(l , r); }
#Verdict Execution timeMemoryGrader output
Fetching results...