QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#864292 | #9311. Protection War | niucard | WA | 967ms | 8524kb | C++14 | 4.2kb | 2025-01-20 14:07:07 | 2025-01-20 14:07:08 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
int n,q,a[300010],len,l[1010],r[1010],id[300010];
long long b1[1010],b2[1010],c[300010];
set<pair<int,int> > s;
void Add(int L,int R,int y)
{
b2[id[L]]-=c[L]*L,b2[id[R+1]]-=c[R+1]*(R+1);
c[L]+=y,c[R+1]-=y;
b1[id[L]]+=y,b1[id[R+1]]-=y;
b2[id[L]]+=c[L]*L,b2[id[R+1]]+=c[R+1]*(R+1);
}
long long ask(int L,int R)
{
long long num1=0,num2=0;
if(L!=1)
{
for(int i=1;i<id[L-1];i++)
num1+=b1[i]*L-b2[i];
for(int i=l[id[L-1]];i<L;i++)
num1+=L*c[i]-i*c[i];
}
for(int i=1;i<id[R];i++)
num2+=b1[i]*(R+1)-b2[i];
for(int i=l[id[R]];i<=R;i++)
num2+=(R+1)*c[i]-i*c[i];
return num2-num1;
}
void bh()
{
set<pair<int,int> >::iterator it=s.begin();
while(it!=s.end())
{
pair<int,int> x=(*it);
if(x.second!=n)
{
Add(x.second,x.second,-ask(x.second,x.second));
s.erase(it);
if(x.first!=x.second)
{
it=(s.insert(make_pair(x.first,x.second-1))).first;
it++;
}
else
it=s.lower_bound(make_pair(x.first,0));
}
else
it++;
}
}
int main()
{
// freopen("cin.in","r",stdin);
// freopen("out.out","w",stdout);
memset(l,0x3f,sizeof l);
scanf("%d%d",&n,&q);
len=sqrt(n);
for(int i=1;i<=n;i++)
{
id[i]=(i-1)/len+1;
l[id[i]]=min(l[id[i]],i),r[id[i]]=max(r[id[i]],i);
}
for(int i=1;i<=n;i++)
{
scanf("%d",&a[i]);
Add(i,i,a[i]);
}
s.insert(make_pair(1,n));
while(q--)
{
int op;
scanf("%d",&op);
if(op==1)
{
int x,y;
scanf("%d%d",&x,&y);
Add(x,x,y-ask(x,x));
if(y)
{
set<pair<int,int> >::iterator it=s.upper_bound(make_pair(x,1e9)),itt;
if(it!=s.begin())
it--;
else
{
if(it==s.end()||(*it).first>x+1)
s.insert(make_pair(x,x));
else
{
int R=(*it).second;
s.erase(it);
s.insert(make_pair(x,R));
}
bh();
continue;
}
if((*it).second>=x)
{
bh();
continue;
}
itt=it,it++;
pair<int,int> x1=(*itt),x2=(*it);
if(x1.second+1==x&&x2.first-1==x)
{
it++;
s.erase(itt,it);
s.insert(make_pair(x1.first,x2.second));
}
else if(x1.second+1==x)
{
s.erase(itt);
s.insert(make_pair(x1.first,x));
}
else if(x2.first-1==x)
{
s.erase(it);
s.insert(make_pair(x,x2.second));
}
else
s.insert(make_pair(x,x));
}
else
{
set<pair<int,int> >::iterator it=s.upper_bound(make_pair(x,1e9)),itt;
if(it!=s.begin())
it--;
else
{
bh();
continue;
}
if((*it).second<x)
{
bh();
continue;
}
pair<int,int> x1=(*it);
s.erase(it);
if(x1.first==x)
{
if(x1.first!=x1.second)
s.insert(make_pair(x1.first+1,x1.second));
}
else if(x1.second==x)
s.insert(make_pair(x1.first,x1.second-1));
else
{
s.insert(make_pair(x1.first,x-1));
s.insert(make_pair(x+1,x1.second));
}
}
}
else if(op==2)
{
int L,R,v;
scanf("%d%d%d",&L,&R,&v);
Add(L,R,v);
set<pair<int,int> >::iterator it1=s.lower_bound(make_pair(L,1e9)),it2=s.upper_bound(make_pair(R,1e9)),it3;
if(it2!=s.begin())
{
it3=it2;
it3--;
R=max(R,(*it3).second);
}
s.erase(it1,it2);
it1=(s.insert(make_pair(L,R))).first;
if(it1!=s.begin())
{
it2=it1;
it1--;
pair<int,int> x=(*it1);
if(x.second>=L-1)
{
it2++;
s.erase(it1,it2);
it1=(s.insert(make_pair(x.first,R))).first;
}
else
it1=it2;
}
it2=it1,it1++;
if(it1!=s.end())
{
pair<int,int> x=(*it1),y=(*it2);
if(x.first<=R+1)
{
it1++;
s.erase(it2,it1);
s.insert(make_pair(y.first,x.second));
}
}
}
else if(op==3)
{
for(set<pair<int,int> >::iterator it=s.begin();it!=s.end();it++)
{
pair<int,int> x=(*it);
Add(x.first,x.second,1);
}
}
else if(op==4)
{
for(set<pair<int,int> >::iterator it=s.begin();it!=s.end();it++)
{
pair<int,int> x=(*it);
Add(x.first,x.second,x.second-x.first+1);
}
}
else
{
int L,R;
scanf("%d%d",&L,&R);
printf("%lld\n",ask(L,R));
}
bh();
}
return 0;
}
詳細信息
Test #1:
score: 100
Accepted
time: 0ms
memory: 5956kb
input:
10 8 1 2 3 4 5 6 7 8 9 10 1 5 0 4 5 1 10 2 1 7 10 5 1 7 1 5 0 3 5 1 7
output:
74 97 71
result:
ok 3 number(s): "74 97 71"
Test #2:
score: 0
Accepted
time: 108ms
memory: 5960kb
input:
500 300000 20001 40132 29212 16930 79791 32181 87513 9436 61594 60199 23626 56049 76877 26228 46852 90808 52774 97868 84080 20953 39737 27635 93897 50290 59947 50049 48449 69397 73015 60257 27292 82311 2349 40210 30130 62403 95726 30729 28690 69685 48849 16781 91994 30976 22114 43258 99392 77848 384...
output:
1777087 6304031 39352977 61099409 15756683 31610555 44754327 12487869 59587103 2013274 3787120 9520811 30097273 0 29379053 97470237 16716946 10173160 60903053 77967400 42424120 82321580 1362621 19339692 48461160 173887621 191344136 26872842 98980145 89270173 54079590 73055561 53268415 64611723 21370...
result:
ok 60308 numbers
Test #3:
score: 0
Accepted
time: 108ms
memory: 8016kb
input:
500 300000 3661 36740 51832 61516 76116 24936 6180 33534 84366 8372 97227 47341 2526 19922 41191 86094 37721 71264 99337 54956 80744 56721 73555 85761 89738 85868 62174 27710 74319 38092 35510 44105 96574 35486 72952 53626 88784 66790 47099 37245 17138 48570 66404 18867 14727 93189 20368 208 92836 9...
output:
14046143 20948450 2866449 26237759 17432940 22077719 42448823 6203132 42995489 13023558 83271628 46227856 14594620 72259746 31434457 53554700 57705358 17165033 162671227 128280776 146609232 133716010 94318636 13656985 73755685 8630665 77502753 144457801 106411744 8636969 186415804 59188599 141850862...
result:
ok 59918 numbers
Test #4:
score: -100
Wrong Answer
time: 967ms
memory: 8524kb
input:
300000 300000 57451 36906 78465 95706 19070 48873 54372 46322 22034 19942 23717 25586 79904 74145 51471 62558 50792 70621 4724 68730 47246 26210 7754 60498 54168 7614 62761 36563 92242 46335 69583 58448 61354 34810 64860 92478 82964 20840 36278 63608 90438 51236 50182 48955 68925 67502 90010 6315 60...
output:
24038355781 17520159076 77426274356 112236455136 233944213210 127898744311 175688445771 426885053349 239002345886 22295671469 136802216849 462348680839 382946706667 801141945001 573484605895 173524140651 14447679142 630305728424 9442569891 261017396115 1080207552674 110655277820 340172946827 1636415...
result:
wrong answer 8367th numbers differ - expected: '280506139256013', found: '280510434223309'