Submission #949701

#TimeUsernameProblemLanguageResultExecution timeMemory
949701amirhoseinfar1385Secret (JOI14_secret)C++17
0 / 100
400 ms8528 KiB
#include "secret.h" #include<bits/stdc++.h> using namespace std; const int maxn=1000+10; int n,all[maxn],dp[maxn][maxn]; int pors(int l,int r){ if(l==r){ return all[l]; } return Secret(all[l],dp[l+1][r]); } int pors2(int l,int r){ if(l==r){ return all[l]; } return Secret(dp[l][r-1],all[r]); } void create(int l,int r){ if(l>r){ return ; } int m=(l+r)>>1; for(int i=m;i>=l;i--){ dp[i][m]=pors(i,m); //cout<<i<<" "<<m<<" "<<dp[i][m]<<"\n"; } for(int i=m+1;i<=r;i++){ dp[i][m]=pors2(m+1,i); //cout<<i<<" "<<m<<" "<<dp[i][m]<<"\n"; } create(m+1,r); create(l,m-1); } void Init(int N, int A[]) { n=N; for(int i=0;i<n;i++){ all[i]=A[i]; } create(0,n-1); } int solve(int l,int r,int tl=0,int tr=n-1){ int m=(tl+tr)/2; if(l>m&&r>m){ return solve(l,r,m+1,tr); } if(l<m&&r<m){ return solve(l,r,l,m-1); } if(l==m){ return Secret(all[l],dp[r][m]); } if(r==m){ return dp[l][m]; } //cout<<l<<" "<<m<<" "<<r<<" "<<dp[l][m]<<" "<<dp[r][m]<<"\n"; return Secret(dp[l][m],dp[r][m]); } int Query(int L, int R) { if(L==R){ return all[L]; } return solve(L,R); }
#Verdict Execution timeMemoryGrader output
Fetching results...