Submission #735796

#TimeUsernameProblemLanguageResultExecution timeMemory
735796WaelSecret (JOI14_secret)C++14
6 / 100
474 ms8396 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] , ans[M][M] , cnt; void Go(int x = 1 , int lx = 1 , int rx = Size) { if(lx == rx) return; int mid = (lx + rx) / 2; int a = mid , b = mid + 1; for(int i = b + 1 ; i <= rx ; ++i) ans[b][i] = Secret(ans[b][i - 1] , s[i]); for(int i = a - 1 ; i >= lx ; --i) ans[i][a] = Secret(s[i] , ans[i + 1][a]); 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 < r) res = Secret(ans[l][mid] , ans[mid + 1][r]); else 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] , ans[i][i] = s[i]; Go(); } int Query(int l , int r) { ++cnt; ++l , ++r; if(l == r) return s[l]; return Get(l , r); }
#Verdict Execution timeMemoryGrader output
Fetching results...