ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#158949 | #10. 小x的城池 | LightningUZ | 10 | 1146ms | 83960kb | C++11 | 5.0kb | 2022-08-24 09:24:06 | 2022-08-24 09:24:08 |
answer
#include<bits/stdc++.h>
using namespace std;
#define N 100005
#define F(i,l,r) for(int i=(l);i<=(r);++i)
#define D(i,r,l) for(int i=(r);i>=(l);--i)
#define MEM(x,a) memset(x,a,sizeof(x))
int I() {char c=getchar(); int x=0; int f=1; while(c<'0' or c>'9') f=(c=='-')?-1:1,c=getchar(); while(c>='0' and c<='9') x=(x<<1)+(x<<3)+(c^48),c=getchar(); return ((f==1)?x:-x);}
int n,val[N]; char typ[N];
struct node
{
int len,ans,drs,pos; int li,ri,lo,ro;
int cl[76],cr[76];
void prt()
{
printf("len=%d ans=%d li=%d ri=%d lo=%d ro=%d drs=%d pos=%d\n",len,ans,li,ri,lo,ro,drs,pos);
printf("cl: "); F(i,0,75)if(cl[i]) printf("%d,%d ",i,cl[i]); puts("");
printf("cr: "); F(i,0,75)if(cr[i]) printf("%d,%d ",i,cr[i]); puts("");
}
};
node sing(int p,int x){char _=typ[p]; node t=(node){1,0,0,-1,-1,-1,-1,-1};MEM(t.cl,0);MEM(t.cr,0); if(_=='A')t.cl[x]=t.cr[x]=1,t.pos=p;else t.li=t.ri=t.lo=t.ro=x; return t;}
node mg_r(node A,node B)
{
node C; C.ans=A.ans+B.ans; C.len=A.len+B.len; C.drs=A.drs+B.drs;
F(i,0,B.li-1)C.ans+=A.cr[i];
F(i,0,75)C.cl[i]=A.cl[i],C.cr[i]=B.cr[i];
C.li=A.li; C.lo=A.lo; C.ri=B.ri; C.ro=B.ro;
C.pos=-1;
if(B.drs==0) {C.pos=A.pos; F(i,max(B.li,0),75)C.cr[i]+=A.cr[i]; C.ro=max(C.ro,A.ro);}
if(A.drs==0) {C.li=max(C.li,B.li);}
if(A.pos>0)
{
if(val[A.pos]<B.li && val[A.pos]>=A.ro && val[A.pos]>=A.lo) C.cl[val[A.pos]]--;
if(val[A.pos]<B.li && val[A.pos]>=A.ro && val[A.pos]<A.lo)
{
/*
puts("=================================");
printf("fuck when merge-r A,B:\n");
A.prt(); B.prt();
puts("=================================");
--C.ans;
*/
}
}
return C;
}
node mg_l(node A,node B)
{
node C; C.ans=A.ans+B.ans; C.len=A.len+B.len; C.drs=A.drs+B.drs+1;
F(i,0,A.ri-1)C.ans+=B.cl[i];
F(i,0,75)C.cl[i]=A.cl[i],C.cr[i]=B.cr[i];
C.li=A.li; C.lo=A.lo; C.ri=B.ri; C.ro=B.ro;
C.pos=-1;
if(A.drs==A.len-1) {C.pos=B.pos; F(i,max(A.ri,0),75)C.cl[i]+=B.cl[i]; C.lo=max(C.lo,B.lo);}
if(B.drs==B.len-1) {C.ri=max(C.ri,A.ri);}
if(B.pos>0)
{
if(val[B.pos]<A.ri && val[B.pos]>=B.lo && val[B.pos]>=B.ro) C.cr[val[B.pos]]--;
if(val[B.pos]<A.ri && val[B.pos]>=B.lo && val[B.pos]<B.ro)
{
/*
puts("=================================");
printf("fuck when merge-l A,B:\n");
A.prt(); B.prt();
puts("=================================");
--C.ans;
*/
}
}
/*
if(B.ro==22 and C.ro!=22)
{
printf("fuck! B.ro=%d C.ro=%d\n",B.ro,C.ro);
}
*/
return C;
}
class SegT
{
public:
int dir[N]; int rv[N<<2];
node a[N<<2],ra[N<<2];
#define ls u<<1
#define rs u<<1|1
#define ll ls,L,mid
#define rr rs,mid+1,R
void up(int u,int L,int R)
{
int mid=(L+R)>>1,d=dir[mid];
if(d==0)a[u]=mg_r(a[ls],a[rs]),ra[u]=mg_l(ra[ls],ra[rs]);
else a[u]=mg_l(a[ls],a[rs]),ra[u]=mg_r(ra[ls],ra[rs]);
/*
if(L>=20 and R==23)
{
printf("update %d[%d,%d] dir:%d\n",u,L,R,dir[mid]);
printf("now ro=%d\n",a[u].ro);
}
*/
}
void build(int u=1,int L=1,int R=n)
{
if(L==1 and R==n)
{
MEM(dir,0);
}
if(L==R)
{
ra[u]=a[u]=sing(L,val[L]);
return;
}
int mid=(L+R)>>1;
build(ll); build(rr); up(u,L,R);
// printf("u=%d [%d,%d]\n",u,L,R);
// a[u].prt();
}
void rv1(int u)
{
swap(a[u],ra[u]); rv[u]^=1;
}
void down(int u,int L,int R)
{
if(rv[u])
{
int mid=(L+R)>>1;
dir[mid]^=1;
rv1(ls); rv1(rs);
rv[u]=0;
}
}
void rev(int l,int r,int u=1,int L=1,int R=n)
{
if(l<=L and R<=r) {rv1(u); return;}
int mid=(L+R)>>1; down(u,L,R);
if(r<=mid) rev(l,r,ll);
else if(mid<l) rev(l,r,rr);
else {rev(l,r,ll),rev(l,r,rr),dir[mid]^=1;}
up(u,L,R);
// printf("pushup u=%d[%d,%d] dir:%d ans=%d\n",u,L,R,dir[mid],a[u].ans);
}
void change(int p,int x,int u=1,int L=1,int R=n)
{
if(L==R)
{
ra[u]=a[u]=sing(p,x);
return;
}
int mid=(L+R)>>1; down(u,L,R);
if(p<=mid) change(p,x,ll); else change(p,x,rr);
up(u,L,R);
}
void prt(int u=1,int L=1,int R=n)
{
printf("u=%d [%d,%d]\n",u,L,R);
a[u].prt();
if(L==R)return;
down(u,L,R); int mid=(L+R)>>1;
prt(ll);prt(rr);
}
void downall(int u=1,int L=1,int R=n)
{
if(L==R)return;
int mid=(L+R)>>1; down(u,L,R);
downall(ll);downall(rr);
}
}T;
void flandre()
{
n=I(); int q=I();
F(i,1,n)
{
int v=I(); char __[10];scanf("%s",__); char c=__[0];
val[i]=v; typ[i]=c;
}
T.build();
F(_,1,q)
{
char o[10];scanf("%s",o);
if(o[0]=='R')
{
int l=I(),r=I();
T.rev(l,r);
}
else
{
int p=I(),x=I();
val[p]=x;
T.change(p,x);
}
printf("%d\n",T.a[1].ans);
if(0 && _==2936)
{
T.prt();
F(i,1,n)
{
printf("%d",val[i]);
if(i<n)printf(T.dir[i]?"<-":"->");
} puts("");
int _drs=0;F(i,1,n-1)_drs+=T.dir[i];
printf("drs expected: %d\n",_drs);
}
// T.downall();
/*
F(i,1,n)
{
printf("%d",val[i]);
if(i<n)printf(T.dir[i]?"<-":"->");
}puts("");
*/
}
}
int main()
{
int t=1;
while(t-->0){flandre();}
return 0;
}
详细
小提示:点击横条可展开更详细的信息
Subtask #1:
score: 10
Accepted
Test #1:
score: 10
Accepted
time: 0ms
memory: 1628kb
input:
7 5 0 A 32 B 10 B 27 B 25 A 30 B 10 A UPDATE 1 1 UPDATE 6 22 UPDATE 1 50 UPDATE 6 62 UPDATE 5 67
output:
2 1 0 2 1
result:
ok 5 number(s): "2 1 0 2 1"
Test #2:
score: 0
Accepted
time: 0ms
memory: 1648kb
input:
10 20 38 A 0 B 2 A 20 A 2 B 31 A 0 B 68 A 53 A 74 B UPDATE 7 63 UPDATE 7 0 UPDATE 7 66 UPDATE 7 7 UP...
output:
6 6 6 6 6 4 5 4 6 4 1 4 1 6 6 4 6 6 6 4
result:
ok 20 numbers
Test #3:
score: 0
Accepted
time: 0ms
memory: 1940kb
input:
100 100 38 A 0 B 2 A 20 A 2 B 31 A 0 B 68 A 53 A 74 B 37 A 62 A 59 A 70 A 71 A 4 A 44 A 2 B 63 A 22 ...
output:
67 67 67 67 67 67 67 67 67 63 63 66 66 66 70 70 70 70 65 64 65 54 45 69 70 69 69 46 67 67 67 67 67 6...
result:
ok 100 numbers
Test #4:
score: 0
Accepted
time: 4ms
memory: 4188kb
input:
1000 500 38 A 49 A 67 A 60 A 62 A 74 A 31 A 6 A 18 A 23 A 45 A 25 A 37 A 62 A 59 A 70 A 71 A 4 A 44 ...
output:
541 629 540 750 742 701 701 737 737 745 737 701 730 701 764 764 723 463 556 635 627 755 755 452 530 ...
result:
ok 500 numbers
Test #5:
score: 0
Accepted
time: 0ms
memory: 1652kb
input:
10 30 38 A 49 A 72 B 2 B 74 B 65 A 74 B 0 B 54 A 2 B REVERSE 7 9 REVERSE 1 5 REVERSE 4 7 REVERSE 6 7...
output:
4 2 2 2 0 3 3 2 2 2 2 2 1 1 2 2 1 2 1 0 1 2 2 2 2 3 3 3 2 1
result:
ok 30 numbers
Test #6:
score: 0
Accepted
time: 4ms
memory: 2268kb
input:
200 400 38 A 49 A 67 A 60 A 62 A 74 A 31 A 6 A 18 A 23 A 45 A 25 A 37 A 62 A 59 A 70 A 71 A 4 A 44 A...
output:
143 100 52 74 68 74 57 33 42 42 39 27 26 45 45 45 22 26 46 43 47 39 32 22 29 22 23 19 26 26 28 28 19...
result:
ok 400 numbers
Test #7:
score: 0
Accepted
time: 8ms
memory: 4200kb
input:
1000 1000 30 A 59 A 17 A 15 A 65 A 3 A 9 A 60 A 31 A 56 A 16 A 63 A 47 A 47 A 45 A 43 A 28 A 11 A 42...
output:
178 312 311 85 85 242 131 194 128 128 134 134 97 90 90 104 64 104 104 136 113 44 117 109 27 27 27 27...
result:
ok 1000 numbers
Test #8:
score: 0
Accepted
time: 0ms
memory: 2916kb
input:
400 400 4 A 16 A 72 A 53 A 73 B 34 A 72 A 31 A 37 A 9 A 7 A 30 A 53 A 15 A 57 A 21 A 69 A 74 A 38 A ...
output:
186 68 129 129 72 67 75 144 97 11 4 4 12 13 17 36 32 13 17 38 15 15 39 39 15 9 17 31 16 16 31 31 24 ...
result:
ok 400 numbers
Test #9:
score: 0
Accepted
time: 0ms
memory: 1632kb
input:
7 4 0 A 32 B 10 B 27 B 25 A 30 B 10 A REVERSE 2 5 UPDATE 5 30 REVERSE 5 7 UPDATE 2 0
output:
2 2 3 1
result:
ok 4 number(s): "2 2 3 1"
Test #10:
score: 0
Accepted
time: 9ms
memory: 4204kb
input:
1000 1000 65 B 28 A 3 B 48 B 19 B 35 B 19 B 12 B 1 B 29 B 18 A 5 B 38 B 16 B 23 B 19 B 22 B 2 B 31 A...
output:
133 133 121 121 121 115 115 119 115 115 113 104 106 107 109 108 103 103 103 94 94 90 90 90 90 90 90 ...
result:
ok 1000 numbers
Test #11:
score: 0
Accepted
time: 13ms
memory: 4204kb
input:
1000 1000 74 A 53 A 32 A 2 B 52 A 19 B 10 B 13 B 15 B 30 B 35 B 15 B 10 B 65 A 64 A 33 A 24 B 32 B 1...
output:
331 319 296 295 286 269 275 252 252 266 265 242 243 232 232 232 227 228 211 222 208 208 209 220 207 ...
result:
ok 1000 numbers
Test #12:
score: 0
Accepted
time: 9ms
memory: 4196kb
input:
1000 1000 43 A 42 A 44 A 56 A 63 A 43 B 22 A 65 A 31 B 8 B 45 A 52 A 32 B 2 B 18 A 6 B 14 A 39 A 0 B...
output:
336 328 328 276 281 280 273 273 273 259 258 258 258 270 271 260 259 254 254 254 254 256 256 259 247 ...
result:
ok 1000 numbers
Test #13:
score: 0
Accepted
time: 8ms
memory: 4204kb
input:
1000 1000 11 B 13 B 23 B 21 B 59 A 29 B 67 A 22 A 1 A 68 A 7 A 65 A 72 A 4 A 42 A 71 A 30 B 41 B 0 B...
output:
449 449 423 372 340 313 299 300 283 283 305 304 265 242 237 240 234 235 230 222 220 220 219 214 218 ...
result:
ok 1000 numbers
Test #14:
score: 0
Accepted
time: 8ms
memory: 4208kb
input:
1000 1000 36 A 12 A 72 A 68 A 25 A 18 A 27 A 52 A 20 A 66 A 15 A 14 A 13 A 29 B 38 A 30 B 24 A 17 A ...
output:
516 515 514 474 474 474 475 438 411 412 424 404 368 362 377 400 365 352 354 354 354 345 345 344 311 ...
result:
ok 1000 numbers
Test #15:
score: 0
Accepted
time: 5ms
memory: 4200kb
input:
1000 1000 10 A 50 A 14 A 72 A 6 A 26 A 24 A 29 A 65 A 65 A 67 A 17 B 0 A 16 A 60 A 64 A 66 A 29 A 27...
output:
499 422 446 430 350 408 314 287 278 267 268 283 276 276 275 251 251 257 198 192 196 220 176 200 200 ...
result:
ok 1000 numbers
Subtask #2:
score: 0
Memory Limit Exceeded
Test #16:
score: 35
Accepted
time: 169ms
memory: 40848kb
input:
10000 10000 38 A 49 A 67 A 60 A 62 A 74 A 31 A 6 A 18 A 23 A 45 A 25 A 37 A 62 A 59 A 70 A 71 A 4 A ...
output:
8481 6987 5555 4171 3408 2277 3351 3046 2441 1321 1328 2040 1303 932 1371 1087 1094 1548 1548 925 15...
result:
ok 10000 numbers
Test #17:
score: 0
Accepted
time: 621ms
memory: 83960kb
input:
30000 30000 38 A 49 A 67 A 60 A 62 A 74 A 31 A 6 A 18 A 23 A 45 A 25 A 37 A 62 A 59 A 70 A 71 A 4 A ...
output:
26871 24611 15656 11163 15669 13968 12964 11293 11339 10586 10586 9096 10933 9996 8370 6666 4011 399...
result:
ok 30000 numbers
Test #18:
score: -35
Memory Limit Exceeded
input:
100000 100000 38 A 49 A 67 A 60 A 62 A 74 A 31 A 6 A 18 A 23 A 45 A 25 A 37 A 62 A 59 A 70 A 71 A 4 ...
output:
result:
Subtask #3:
score: 0
Memory Limit Exceeded
Test #26:
score: 35
Accepted
time: 288ms
memory: 83692kb
input:
30000 30000 38 A 49 A 67 A 60 A 62 A 74 A 31 A 6 A 18 A 23 A 45 A 25 A 37 A 62 A 59 A 70 A 71 A 4 A ...
output:
23611 23608 23608 23608 23343 23343 23343 23343 23343 23343 23608 23608 23608 23608 23608 23608 2172...
result:
ok 30000 numbers
Test #27:
score: -35
Memory Limit Exceeded
input:
100000 100000 3 B 15 B 39 B 8 B 5 B 13 B 2 B 4 B 20 B 5 B 21 B 21 B 10 B 22 B 18 B 2 B 29 B 11 B 14 ...
output:
result:
Subtask #4:
score: 0
Skipped