Submission #930275

#TimeUsernameProblemLanguageResultExecution timeMemory
930275noyancanturkSecret (JOI14_secret)C++17
0 / 100
378 ms4480 KiB
#include "secret.h" #include <cassert> const int lim=1100; int n,*a; int left[12][lim],right[12][lim]; void dnc(int l,int r,int dep=0){ if(l==r){ return; } int mid=(l+r)>>1; assert(left[dep][mid]==0); left[dep][mid]=a[mid]; for(int i=mid-1;l<=i;i--){ assert(left[dep][i]==0); left[dep][i]=Secret(a[i],left[dep][i+1]); } assert(mid+1<=r); assert(right[dep][mid+1]==0); right[dep][mid+1]=a[mid+1]; for(int i=mid+2;i<=r;i++){ assert(right[dep][i]==0); right[dep][i]=Secret(right[dep][i-1],a[i]); } dnc(l,mid,dep+1),dnc(mid+1,r,dep+1); } void Init(int N, int A[]) { n=N; a=A; dnc(0,n-1); } int Query(int L, int R) { if(L==R){ return a[L]; } int l=0,r=n-1,dep=0; while(l<=r){ int mid=(l+r)>>1; if(L<=mid&&mid<R){ return Secret(left[dep][L],right[dep][R]); }else if(mid<L){ l=mid+1; }else{ r=mid-1; } dep++; } return -1; }
#Verdict Execution timeMemoryGrader output
Fetching results...