結果
問題 | No.1568 Sushi |
ユーザー | kmjp |
提出日時 | 2021-07-01 00:23:43 |
言語 | C++17 (gcc 12.3.0 + boost 1.83.0) |
結果 |
AC
|
実行時間 | 807 ms / 2,000 ms |
コード長 | 2,335 bytes |
コンパイル時間 | 2,118 ms |
コンパイル使用メモリ | 204,008 KB |
実行使用メモリ | 165,248 KB |
最終ジャッジ日時 | 2024-06-27 10:14:25 |
合計ジャッジ時間 | 21,763 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 7 ms
9,600 KB |
testcase_01 | AC | 6 ms
9,600 KB |
testcase_02 | AC | 7 ms
9,472 KB |
testcase_03 | AC | 7 ms
9,600 KB |
testcase_04 | AC | 24 ms
13,056 KB |
testcase_05 | AC | 18 ms
10,624 KB |
testcase_06 | AC | 21 ms
11,776 KB |
testcase_07 | AC | 18 ms
10,624 KB |
testcase_08 | AC | 23 ms
12,928 KB |
testcase_09 | AC | 785 ms
129,664 KB |
testcase_10 | AC | 678 ms
95,232 KB |
testcase_11 | AC | 676 ms
99,200 KB |
testcase_12 | AC | 665 ms
96,896 KB |
testcase_13 | AC | 722 ms
128,384 KB |
testcase_14 | AC | 665 ms
91,136 KB |
testcase_15 | AC | 768 ms
157,696 KB |
testcase_16 | AC | 666 ms
93,696 KB |
testcase_17 | AC | 807 ms
164,352 KB |
testcase_18 | AC | 712 ms
124,032 KB |
testcase_19 | AC | 726 ms
129,536 KB |
testcase_20 | AC | 700 ms
93,824 KB |
testcase_21 | AC | 713 ms
123,776 KB |
testcase_22 | AC | 704 ms
114,816 KB |
testcase_23 | AC | 746 ms
152,832 KB |
testcase_24 | AC | 697 ms
115,712 KB |
testcase_25 | AC | 741 ms
140,544 KB |
testcase_26 | AC | 769 ms
154,880 KB |
testcase_27 | AC | 782 ms
165,248 KB |
testcase_28 | AC | 701 ms
109,696 KB |
ソースコード
#include <bits/stdc++.h> using namespace std; typedef signed long long ll; #define _P(...) (void)printf(__VA_ARGS__) #define FOR(x,to) for(x=0;x<(to);x++) #define FORR(x,arr) for(auto& x:arr) #define FORR2(x,y,arr) for(auto& [x,y]:arr) #define ALL(a) (a.begin()),(a.end()) #define ZERO(a) memset(a,0,sizeof(a)) #define MINUS(a) memset(a,0xff,sizeof(a)) template<class T> bool chmax(T &a, const T &b) { if(a<b){a=b;return 1;}return 0;} template<class T> bool chmin(T &a, const T &b) { if(a>b){a=b;return 1;}return 0;} //------------------------------------------------------- ll L; int N,Q; ll A[1<<19]; ll X[1<<19]; ll D; struct node { ll dif; ll ma,mi,up,down; }; node merge(node a,node b) { node v; if(a.ma==0&&a.mi==0) return b; if(b.ma==0&&b.mi==0) return a; v.dif=a.dif+b.dif; v.ma=max(a.ma,a.dif+b.ma); v.mi=min(a.mi,a.dif+b.mi); v.up=max({a.up,b.up,b.ma+a.dif-a.mi}); v.down=min({a.down,b.down,b.mi+a.dif-a.ma}); return v; } node V[20][1<<19]; void solve() { int i,j,k,l,r,x,y; string s; cin>>L>>N>>Q; A[0]=0; FOR(i,N) { cin>>A[i+1]; } for(i=N+1;i<1<<18+1;i++) A[i]=1LL<<53; for(i=1;i<1<<18;i++) { if(i%2==1) X[i]=X[i-1]+A[i]-A[i-1]; else X[i]=X[i-1]-(A[i]-A[i-1]); } N+=2; FOR(i,N-1) { node& v=V[0][i]; v.dif=X[i+1]-X[i]; if(X[i+1]>X[i]) { v.dif=v.ma=v.up=X[i+1]-X[i]; v.mi=v.down=0; } else { v.dif=v.mi=v.down=X[i+1]-X[i]; v.ma=v.up=0; } } FOR(i,19) FOR(j,N) V[i+1][j]=merge(V[i][j],V[i][j+(1<<i)]); while(Q--) { ll B,C; cin>>B>>C; B=(B+D)%L; C=(C+D)%1000000000000000LL; x=lower_bound(A,A+N,C+1)-A-1; ll dif; if(X[x]<X[x+1]) { dif=A[x+1]-C; } else { dif=-(A[x+1]-C); } if(dif>=B) { D=B; } else if(dif<=B-L) { D=abs(B-L); } else { node v; v.dif=dif; v.ma=v.up=max(0LL,v.dif); v.mi=v.down=min(0LL,v.dif); x++; for(i=18;i>=0;i--) { node v2=merge(v,V[i][x]); if(v2.up<B&&v2.down>B-L) { x+=1<<i; v=v2; } } if(X[x]<X[x+1]) { D=A[x]+(B-(v.dif-v.mi))-C; } else { D=A[x]+(-(v.ma-v.dif)-(B-L))-C; } } cout<<D<<endl; } } int main(int argc,char** argv){ string s;int i; if(argc==1) ios::sync_with_stdio(false), cin.tie(0); FOR(i,argc-1) s+=argv[i+1],s+='\n'; FOR(i,s.size()) ungetc(s[s.size()-1-i],stdin); cout.tie(0); solve(); return 0; }