제출 #1123189

#제출 시각아이디문제언어결과실행 시간메모리
1123189razivoThe short shank; Redemption (BOI21_prison)C++20
0 / 100
184 ms17208 KiB
#include <iostream> #include <queue> #include <vector> #include <tuple> using namespace std; vector<long long> v(2e6); vector<bool> fil(2e6); pair<pair<long long,long long>,long long> opt(long long i, long long j) { long long best = 0; long long bestpos = j-1; long long last = j-1; vector<long long> q; long long val = 0; for (long long k = i; k < j; ++k) { if(v[k]==-1) { if(val>0) { val--; fil[k]=true; }else { fil[k]=false; } }else { fil[k]=true; val = max(val,v[k]); } } long long cnt = 0; for (long long k = j-1; k >=i; --k) { if(v[k]==-1) { if(!fil[k]) cnt++; q.push_back(k); continue; } long long p = k+v[k]; if(q.size()-cnt>best) { best=q.size()-cnt; bestpos=k; } if(!fil[k]) cnt++; while(!q.empty() && q.back()<p) { q.pop_back(); } } return {{cnt,best},bestpos}; } int main() { long long n,d,t; cin>>n>>d>>t; for (long long i = 0; i < n; ++i) { long long x; cin>>x; if(x>t) v[i]=-1; else v[i]=t-x+1; } priority_queue<pair<long long,tuple<long long,long long,long long>>> q; auto [a,b] = opt(0,n); auto [l,m] = a; long long init = n-l; q.push({m,{b,0,n}}); for (long long i = 0; i < d; ++i) { auto [a,b] = q.top(); q.pop(); auto [p,l,r] = b; init-=a; auto [u,v] = opt(l,p+1); auto [u2,v2] = opt(p+1,r); q.push({u.second,{v,l,p+1}}); q.push({u2.second,{v2,p+1,r}}); } cout<<init<<endl; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...