麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 學(xué)院 > 開發(fā)設(shè)計(jì) > 正文

BZOJ 3223, 文藝平衡樹

2019-11-11 05:49:45
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

PRoblem

傳送門

Mean

編寫一個(gè)支持對(duì)數(shù)列進(jìn)行翻轉(zhuǎn)子串操作的數(shù)據(jù)結(jié)構(gòu)。

Analysis

Splay裸題。 只需要支持翻轉(zhuǎn)操作即可。 輸出數(shù)列時(shí)一個(gè)一個(gè)查詢就是了……

Code

#include<cstdio>const int N=100005;int n,m,o,x,y,cnt,a[N],val[N],f[N],sz[N],son[N][2];bool rev[N];void swap(int &x,int &y){int z=x;x=y;y=z;}void revl(int x){if(!x) return;swap(son[x][0],son[x][1]);rev[x]^=1;}void read(int &x){ char c; while((c=getchar())<'0' || c>'9'); x=c-'0'; while((c=getchar())>='0' && c<='9') x=x*10+c-'0';}void pb(int x){ if(rev[x]){ revl(son[x][0]); revl(son[x][1]); rev[x]=0; }}void up(int x){ int l=son[x][0],r=son[x][1]; sz[x]=sz[l]+sz[r]+1;}int build(int l,int r,int fa){ int x=++cnt,mid=l+r>>1; f[x]=fa,val[x]=mid; if(l<mid) son[x][0]=build(l,mid-1,x); if(r>mid) son[x][1]=build(mid+1,r,x); up(x); return x;}int kth(int k){ int x=o,tmp; while(1){ pb(x); tmp=sz[son[x][0]]+1; if(tmp==k) return x; if(tmp>k) x=son[x][0]; else k-=tmp,x=son[x][1]; }}void rotate(int x){ int y=f[x],w=son[y][1]==x; son[y][w]=son[x][w^1]; if(son[x][w^1]) f[son[x][w^1]]=y; if(f[y]) son[f[y]][son[f[y]][1]==y]=x; f[x]=f[y],son[x][w^1]=y,f[y]=x; up(y);}void splay(int x,int w){ int s=1,i=x,y;a[1]=x; while(f[i]) a[++s]=i=f[i]; while(s) pb(a[s--]); while(f[x]!=w){ y=f[x]; if(f[y]!=w){if((son[f[y]][0]==y)^(son[y][0]==x)) rotate(x);else rotate(y);} rotate(x); } if(!w) o=x; up(x);}int main(){ read(n),read(m); o=build(0,n+1,0); while(m--){ read(x),read(y); x=kth(x),y=kth(y+2); splay(x,0),splay(y,x); revl(son[y][0]); up(y),up(x); } for(int i=2;i<=n;i++) printf("%d ",val[kth(i)]); printf("%d",val[kth(n+1)]); return 0;}
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 依人在线视频 | 亚洲欧美国产视频 | av在线浏览 | 日本成人午夜视频 | 黄色片快播 | 久久草在线观看视频 | 精品国产91久久久 | 国产91丝袜在线熟 | 久草在线新时代视觉 | av亚洲在线观看 | 日韩黄色免费电影 | 成人18免费观看 | 精品国产乱码久久久久久久 | 在线成人一区二区 | 麻豆视频国产在线观看 | 天天碰天天操 | 成熟女人特级毛片www免费 | 日韩中文一区 | 毛片在线免费播放 | 91 成人| 中国av免费观看 | 成人毛片100免费观看 | 高清成人在线 | 国产免费一区二区三区网站免费 | 国产精品久久久久久久四虎电影 | 国产69久久精品成人看 | 欧美人xxx| 国产中文av在线 | 免费在线观看成人av | 国产精品久久久久久久久久iiiii | 手机在线看片国产 | 九色在线78m| 91久久九色| 欧美精品一区自拍a毛片在线视频 | chinese xvideos gay| 成人午夜小视频 | 免费的毛片 | 91九色蝌蚪国产 | 亚洲小视频网站 | 毛片福利| 一级黄色影片在线观看 |