Submission #1106041

#TimeUsernameProblemLanguageResultExecution timeMemory
1106041hainam2k9Secret (JOI14_secret)C++17
0 / 100
312 ms11620 KiB
#include <bits/stdc++.h> #include <secret.h> #define tt cin.tie(0), cout.tie(0), ios_base::sync_with_stdio(0) #define fo freopen((NAME+".INP").c_str(), "r", stdin), freopen((NAME+".OUT").c_str(), "w", stdout) #define ll long long #define ull unsigned long long #define i128 __int128 #define db long double #define sz(a) ((int)(a).size()) #define pb emplace_back #define pf emplace_front #define pob pop_back #define pof pop_front #define lb lower_bound #define ub upper_bound #define fi first #define se second #define ins emplace using namespace std; const int MOD = 1e9+7, MAXN = 1e5+5; const string NAME = ""; pair<int,bool> val[1005][1005]; void preprocess(int l, int r, int a[]){ int mid=(l+r)>>1; val[mid][mid].fi=a[mid], val[mid][mid].se=1; if(l==r) return; preprocess(l,mid,a); preprocess(mid+1,r,a); for(int i = mid-1; i>=l; --i) if(!val[i][mid].se) val[i][mid].fi=Secret(val[i+1][mid].fi,a[i]), val[i][mid].se=1; for(int i = mid+1; i<=r; ++i) if(!val[mid][i].se) val[mid][i].fi=Secret(val[mid][i-1].fi,a[i]), val[mid][i].se=1; } void Init(int n, int a[]){ for(int i = n; i>0; --i) swap(a[i],a[i-1]); preprocess(1,n,a); } int Query(int l, int r){ for(int i = l; i<r; ++i) if(val[l][i].se&&val[i+1][r].se) return Secret(val[l][i].fi,val[i+1][r].fi); return val[l][l].fi; }
#Verdict Execution timeMemoryGrader output
Fetching results...