日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

2020牛客国庆集训派对day8G-Shuffle Cards【Splay】

發布時間:2023/12/3 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 2020牛客国庆集训派对day8G-Shuffle Cards【Splay】 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

正題

題目鏈接:https://ac.nowcoder.com/acm/contest/7865/G


題目大意

nnn個數從1~n1\sim n1nmmm次拿出其中一段放到頭部,求最終序列。


解題思路

SplaySplaySplay拿出一段區間然后丟到頭部就好了。

時間復雜度O(nlog?n)O(n\log n)O(nlogn)


codecodecode

#include<cstdio> #include<cstring> #include<algorithm> using namespace std; const int N=1e5+10; int n,m,root,siz[N],fa[N],val[N],t[N][2]; void PushUp(int x) {siz[x]=siz[t[x][0]]+siz[t[x][1]]+1;return;} bool Direct(int x) {return t[fa[x]][1]==x;} void Connect(int x,int y,int dir) {t[x][dir]=y;fa[y]=x;return;} void Rotate(int x){int y=fa[x],z=fa[fa[x]];int xs=Direct(x),ys=Direct(y);Connect(y,t[x][xs^1],xs);Connect(x,y,xs^1);Connect(z,x,ys);PushUp(y);PushUp(x); return; } void Splay(int x,int f){while(fa[x]!=f){int up=fa[x];if(fa[up]==f)Rotate(x);else if(Direct(x)==Direct(up))Rotate(up),Rotate(x);else Rotate(x),Rotate(x);}if(!f)root=x;return; } int Find(int x,int k){if(siz[t[x][0]]>=k)return Find(t[x][0],k);if(siz[t[x][0]]+1==k)return x;return Find(t[x][1],k-siz[t[x][0]]-1); } void Write(int x){if(!x)return;Write(t[x][0]);if(val[x])printf("%d ",val[x]);Write(t[x][1]); } int main() {scanf("%d%d",&n,&m);siz[1]=1;for(int i=2;i<=n+1;i++){val[i]=i-1;fa[i-1]=i;t[i][0]=i-1;PushUp(i);}t[n+2][0]=n+1;fa[n+1]=n+2;PushUp(n+2);root=n+2; for(int i=1;i<=m;i++){int l,r,x,y,tmp;scanf("%d%d",&l,&r);r=l+r-1;x=Find(root,l);y=Find(root,r+2);Splay(x,0);Splay(y,x);tmp=t[y][0];t[y][0]=0;fa[tmp]=0;PushUp(y);x=Find(root,1);y=Find(root,2);Splay(x,0);Splay(y,x);t[y][0]=tmp;fa[tmp]=y;Splay(tmp,0);root=tmp;}Write(root); }

總結

以上是生活随笔為你收集整理的2020牛客国庆集训派对day8G-Shuffle Cards【Splay】的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 三级欧美韩日大片在线看 | 天天插天天色 | 超碰97在线免费 | 日韩色中色 | 久久人人视频 | 东方av在线免费观看 | 香港三级韩国三级日本三级 | 国产日韩在线播放 | 亚欧在线 | 99精品欧美 | 久久这里有 | 无码 人妻 在线 视频 | 国产91福利 | 1024视频污 | 欧美夜夜| 国产东北真实交换多p免视频 | 老外一级黄色片 | 亚洲不卡中文字幕 | 久久99精品视频 | 色婷婷综合久久久久中文一区二区 | 久久久久无码精品国产sm果冻 | 日本黄色片免费 | 久久不卡影院 | 尤物在线精品 | 女性毛片 | 污网站在线免费看 | 综合一区在线 | 午夜一级影院 | 欧美日韩高清在线播放 | 永久在线免费观看 | 天堂网视频在线 | 你懂的欧美 | 日本最黄网站 | 久热草 | 日本免费黄色小视频 | 久久桃色 | 天天草天天爽 | 国产黄大片在线观看画质优化 | 日本免费一区二区三区四区五六区 | www.久久国产 | 久久丫丫| v天堂中文在线 | 中出白浆| 国产精品欧美日韩 | 久久免费看少妇高潮 | 久久综合久久久久 | 欧美少妇一级片 | 欧美激情精品 | 真实的国产乱xxxx在线91 | 最新日韩在线视频 | 最新超碰| 日韩短视频 | a在线视频 | 爱爱视频在线免费观看 | www.亚洲一区二区 | 欧美在线www| 国产午夜一级一片免费播放 | 被灌满精子的波多野结衣 | 中文字幕免费看 | 99r精品视频 | 韩国性猛交╳xxx乱大交 | 久久久精品视频网站 | 91精品国产高清 | www.成人av | 13日本xxxxxⅹxxx20 | 久久青 | 人妻与黑人一区二区三区 | 国产成人在线免费观看 | 国产日韩在线观看一区 | 波多野结衣在线视频免费观看 | 免费特级毛片 | 99ri视频| 激情五月俺也去 | 日本久久精品视频 | 日日日日日日bbbbbb | 九草视频在线观看 | 日日操日日操 | а√天堂中文在线资源8 | 性喷潮久久久久久久久 | 精品国自产在线观看 | 精品国产一二三 | 亚洲美女一级片 | 好吊日免费视频 | 天天想你免费观看完整版高清电影 | 电影寂寞少女免费观看 | 色视频免费在线观看 | 久久人人爽人人爽人人片av免费 | 国产精品成人一区二区网站软件 | 精品欧美在线 | 国产中文字幕在线免费观看 | 日韩欧美亚洲视频 | 超碰资源总站 | 国产不卡视频 | ass极品水嫩小美女ass | 欧美人与性禽动交精品 | 五月婷六月 | 久久久久久久久精 | 爱情岛论坛亚洲入口 | 国产又大又黄的视频 |