QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#432964 | #8718. 保区间最小值一次回归问题 | Fesdrer | TL | 347ms | 19428kb | C++17 | 2.3kb | 2024-06-07 21:23:12 | 2024-06-07 21:23:13 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
const int N=5e5+5;
int T,n,m,a[N],nxt[N];
long long ans,f[N];
struct Node{int l,r,v;}que[N];
vector<pair<int,int>> query,base;
vector<int> id;
deque<int> q;
int get(int x){
if(nxt[x]==x) return x;
return nxt[x]=get(nxt[x]);
}
void solve(int v){
while(q.size()) q.pop_back();
f[0]=0;
q.push_back(0);
query.insert(query.begin(),{0,0});
for(int i:id) ans+=max(0,v-a[i]);
id.insert(id.begin(),0);
long long mn=0x3f3f3f3f3f3f3f3f;
for(int i=1,j=0;i<=int(id.size())-1;i++){
while(j<int(query.size())-1&&query[j+1].second<i) j++;
while(q.size()&&q.front()<query[j].first) q.pop_front();
f[i]=f[q.front()]+max(v,a[id[i]])-v;
while(q.size()&&f[q.back()]>=f[i]) q.pop_back();
q.push_back(i);
if(i>=query.back().first&&i<=query.back().second) mn=min(mn,f[i]);
}
ans+=mn;
}
int main(){
// freopen("in.txt","r",stdin);
// freopen("out.txt","w",stdout);
ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
cin>>T;
while(T--){
cin>>n>>m;
for(int i=1;i<=n;i++) cin>>a[i];
for(int i=1;i<=m;i++) cin>>que[i].l>>que[i].r>>que[i].v;
for(int i=1;i<=n+1;i++) nxt[i]=i;
sort(que+1,que+m+1,[&](const Node &x,const Node &y){
if(x.v==y.v) return (x.r==y.r?x.l>y.l:x.r<y.r);
return x.v>y.v;
});
bool flagg=1;
ans=0;
for(int i=1;i<=m;i++){
int l=i,r=i-1;
query.clear(),base.clear(),id.clear();
while(r<n&&que[l].v==que[r+1].v){
r++;
if(query.empty()||que[r].l>query.back().first) query.push_back({que[r].l,que[r].r});
base.push_back({que[r].l,que[r].r});
}
i=r;
bool flag=1;
for(pair<int,int> it:query) if(get(it.first)>it.second) {flag=0;break;}
if(!flag){flagg=0;break;}
for(pair<int,int> it:query) for(int j=get(it.first);j<=it.second;j=get(j+1))
id.push_back(j),nxt[j]=get(j+1);
for(pair<int,int> &it:query){
it.first=lower_bound(id.begin(),id.end(),it.first)-id.begin()+1;
it.second=upper_bound(id.begin(),id.end(),it.second)-id.begin();
}
solve(que[i].v);
id.clear();
for(pair<int,int> it:base) for(int j=get(it.first);j<=it.second;j=get(j+1))
id.push_back(j),nxt[j]=get(j+1);
for(int j:id) ans+=max(0,que[i].v-a[j]);
}
if(flagg) cout<<ans<<endl;
else cout<<-1<<endl;
}
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 1ms
memory: 9984kb
input:
1 3 2 2023 40 41 1 1 2022 2 3 39
output:
2
result:
ok 1 number(s): "2"
Test #2:
score: 0
Accepted
time: 347ms
memory: 19428kb
input:
1000 100 100 1 35141686 84105222 84105220 7273527 178494861 178494861 112519027 77833654 77833656 261586535 278472336 278472336 261586536 416361017 416361017 426649080 323519513 278472337 420127821 420127823 420127823 482516531 434108818 420127821 631535744 615930922 546346921 546346920 546346920 70...
output:
49 46 43 39 48 47 49 46 46 48 47 56 952 53 50 55 46 62 57 46 49 50 42 55 51 57 50 43 41 44 41 53 57 45 59 45 48 44 37 48 43 52 46 50 909 948 48 50 50 50 45 42 54 53 42 46 55 52 51 48 38 48 43 41 55 41 48 47 38 51 54 46 44 47 46 49 43 48 42 45 47 36 43 45 53 46 48 45 42 45 48 40 49 54 44 43 45 48 49 ...
result:
ok 1000 numbers
Test #3:
score: 0
Accepted
time: 328ms
memory: 18136kb
input:
1000 100 100 40 35141748 84105257 84105343 7273633 178494885 178495007 112519027 77833696 77833671 261586538 278472335 278472427 261586652 416361094 416361130 426649132 323519561 278472520 420127898 420127936 420127900 482516532 434108895 420127875 631535939 615931040 546346933 546346951 546347103 7...
output:
5391 5728 5395 4133 4671 3496 3629 5091 5285 5530 4748 5441 84743 6061 4524 6175 5755 5357 3835 5486 4698 5872 4955 5320 4374 5628 4426 4747 5019 4439 4361 5774 6141 6897 5578 5067 5036 5719 4380 4763 4098 4693 4514 5690 92018 84532 4776 5056 4351 5501 4885 4828 5223 6395 3673 6007 6028 5993 5289 45...
result:
ok 1000 numbers
Test #4:
score: 0
Accepted
time: 329ms
memory: 19324kb
input:
1000 100 100 148088468 98149781 583014390 471155624 805747464 361353765 809227446 405213819 979246312 746234854 328924822 293996764 439427756 927284157 709886804 719570910 987283502 607077506 460561747 601690465 661900658 689494603 664094557 738719400 968257412 849232761 704892887 981300891 63494525...
output:
13272909075 10500705683 12729662919 9598250477 14090962014 12379912845 12111344391 11664729042 11963959801 12049221193 11907426860 12443185625 241361559829 15859152345 12213559141 13098156239 16019877206 13030210346 11413013605 12943939894 15243504691 10167904190 13684987690 12625876652 13823026696 ...
result:
ok 1000 numbers
Test #5:
score: -100
Time Limit Exceeded
input:
1000 5 4 2 4 4 3 6 1 5 5 3 4 4 3 3 3 1 2 2 3 1 5 1 5 2 3 6 1 6 1 1 1 3 1 1 1 1 1 6 1 1 6 1 1 5 1 1 6 2 3 5 1 1 2 2 1 2 5 1 2 5 2 2 5 2 1 2 2 1 2 5 4 1 2 6 1 5 1 4 6 1 4 3 1 1 2 1 1 1 1 1 5 1 1 1 1 4 6 1 1 2 1 1 3 1 1 2 1 1 3 3 6 5 5 6 2 3 6 1 2 3 1 3 2 2 3 1 2 3 1 1 1 1 4 3 6 5 6 2 1 2 3 1 2 4 1 3 2...
output:
-1 6