제출 #294369

#제출 시각아이디문제언어결과실행 시간메모리
294369fucking_do_it비밀 (JOI14_secret)C++14
100 / 100
533 ms8440 KiB
#include "secret.h" #include <bits/stdc++.h> #define mid (l+r)/2 using namespace std; const int inf = 1e3+9; int n,a[inf],cnt; int dp[inf][inf]; vector<pair<int,int> > ranges; void build(int l,int r){ ranges.push_back(make_pair(l,r)); if(l == r) return ; for(int i=mid-1;i>=l;i--) dp[i][mid] = Secret(a[i],dp[i+1][mid]); for(int i = mid+2;i<=r;i++) dp[mid+1][i] = Secret(dp[mid+1][i-1],a[i]); build(l,mid); build(mid+1,r); } void Init(int N, int A[]) { n = N; for(int i=1;i<=n;i++) a[i] = A[i-1],dp[i][i] = a[i]; build(1,n); assert(cnt<=8000); } int Query(int x, int y) { x++,y++; for(auto o:ranges){ int l = o.first,r = o.second; if(!(x >= l && r >= y && mid >=x && mid <= y)) continue; if(y == mid || x == mid+1) return dp[x][y]; else return Secret(dp[x][mid],dp[mid+1][y]); } }

컴파일 시 표준 에러 (stderr) 메시지

secret.cpp: In function 'int Query(int, int)':
secret.cpp:47:2: warning: control reaches end of non-void function [-Wreturn-type]
   47 |  }
      |  ^
#Verdict Execution timeMemoryGrader output
Fetching results...