亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

|BZOJ 3224|平衡樹|Tyvj 1728 普通平衡樹

2019-11-14 11:26:04
字體:
來源:轉載
供稿:網友

BZOJ傳送門 平衡樹模板題,注意相同元素的處理。 Treap:

#include<cstdio> #include<algorithm> #include<cstring> #include<vector> #define ms(i,j) memset(i,j, sizeof i); using namespace std; struct node{ node *ch[2];//左右孩子 int v, r;//值,優先級 int s;//附加值:以當前節點為根的結點數量 int w;//附加值:和當前節點相同值的結點數 void mt() { s = w; if (ch[0]!=NULL) s += ch[0]->s; if (ch[1]!=NULL) s += ch[1]->s; } };int ans;struct treap{ node *root; void rotate(int d, node *&o)//d=0則左旋 d=1則右旋 { node *k = o->ch[d^1]; o->ch[d^1] = k->ch[d]; k->ch[d] = o; o->mt(); k->mt(); o = k; } void insert(int x, node *&o)//插入一個數 { if (o==NULL) { o = new node(); o->v = x; o->r = rand(); o->s = o->w = 1; o->ch[0] = o->ch[1] = NULL; //初值 } else if (o->v==x) o->w++; //有相同直接w++ else { int d = (x < o->v ? 0 : 1); insert(x, o->ch[d]); if (o->ch[d]->r > o->r) rotate(d^1, o); } o->mt(); } void del(int x, node *&o)//刪除一個數 { int d = (x < o->v ? 0 : 1); if (o->v==x)//找到 { if (o->w>1) {o->w--; o->s--;} else//不止一個數就直接w--,s-- if (o->ch[0]==NULL) o = o->ch[1]; else if (o->ch[1]==NULL) o = o->ch[0]; else { int d2 = (o->ch[0]->r > o->ch[1]->r ? 1 : 0); rotate(d2,o); del(x, o->ch[d2]); } } else { del(x, o->ch[d]); } if (o!=NULL) o->mt(); } int rank(int x, node *o)//求x的排名 { int tmp; if (o->ch[0]==NULL) tmp = 0; else tmp=o->ch[0]->s;//求s if (o->v==x) return tmp+1;//找到了 else if (o->v >x) return rank(x,o->ch[0]); else return tmp+o->w+rank(x,o->ch[1]); } int kth(int k, node *o)//求第k小 { if (o==NULL||o->s<k||k<=0) return -1;//不符合要求 int tmp; if (o->ch[0]==NULL) tmp = 0; else tmp = o->ch[0]->s;//求s if (k<=tmp) return kth(k,o->ch[0]); else if (k > tmp+o->w) return kth(k - tmp - o->w,o->ch[1]); else return o->v;//找到了 } void PRed(int x, node *o)//求前驅 { if(o==NULL)return; if(o->v<x) { ans = o->v; pred(x, o->ch[1]); } else pred(x, o->ch[0]); } void succ(int x, node *o)//求后繼 { if(o==NULL)return; if(o->v>x) { ans = o->v; succ(x, o->ch[0]); } else succ(x, o->ch[1]); }};treap tree;int n;int main() { scanf("%d", &n); int opt,x; for (int i=1;i<=n;i++) { scanf("%d%d", &opt, &x); switch(opt) { case 1: tree.insert(x, tree.root); break; case 2: tree.del(x, tree.root); break; case 3: printf("%d/n", tree.rank(x, tree.root)); break; case 4: printf("%d/n", tree.kth(x, tree.root)); break; case 5: tree.pred(x,tree.root); printf("%d/n", ans); break; case 6: tree.succ(x,tree.root); printf("%d/n", ans); break; } } return 0; }
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩精品在线第一页| 日韩电影中文字幕在线| 久久久久久久久网站| 亚洲视频免费一区| 日韩暖暖在线视频| 久久免费观看视频| 精品久久久中文| 亚洲国产精品久久精品怡红院| 日韩在线免费观看视频| 久久精品国产亚洲一区二区| 狠狠综合久久av一区二区小说| 久久av在线看| 久久亚洲欧美日韩精品专区| 国产在线视频2019最新视频| 成人免费xxxxx在线观看| 成人av在线网址| 日韩激情视频在线播放| 中国china体内裑精亚洲片| 国产精品中文久久久久久久| 国语自产在线不卡| 欧美成人亚洲成人日韩成人| 亚洲人成电影在线| 国产精品视频久久久久| 亚洲第一在线视频| 国产精品欧美日韩一区二区| 精品美女永久免费视频| 亚洲一区美女视频在线观看免费| 国内精品模特av私拍在线观看| 亚洲国产日韩欧美综合久久| 亚洲女在线观看| 国产视频精品免费播放| 日韩va亚洲va欧洲va国产| 欧美床上激情在线观看| 国产91在线视频| 久久精品亚洲热| 精品视频在线播放| 欧美视频中文在线看| 国产精品旅馆在线| 青青草原一区二区| 欧美另类第一页| 亚洲va欧美va在线观看| 欧美亚洲一级片| 91精品国产成人www| 欧美日韩一区免费| 日韩av片永久免费网站| 欧美成人精品激情在线观看| 亚洲午夜精品久久久久久久久久久久| 成人午夜在线观看| 国产精品久久99久久| 欧美一级视频一区二区| 欧美疯狂性受xxxxx另类| 国产精品久久久久av免费| 精品欧美国产一区二区三区| 免费97视频在线精品国自产拍| 国产精品亚洲综合天堂夜夜| 九九热精品视频在线播放| 亚洲精品国精品久久99热一| 中文字幕久热精品在线视频| 久久人人爽人人| 亚洲精品在线不卡| 91精品视频在线播放| 在线视频日韩精品| xx视频.9999.com| 国产精品色视频| 欧美电影免费观看网站| 欧美在线观看视频| 亚洲男女自偷自拍图片另类| 久久久久久91香蕉国产| 午夜精品美女自拍福到在线| 中文字幕av一区中文字幕天堂| 日韩视频免费看| 久久国产精品久久久久| 55夜色66夜色国产精品视频| 国产美女主播一区| 神马国产精品影院av| 欧美午夜女人视频在线| 亚洲精品www久久久久久广东| 亚洲欧美日韩爽爽影院| 中文字幕亚洲欧美一区二区三区| 国产一区二区三区丝袜| 成人精品一区二区三区电影黑人| 国产欧美va欧美va香蕉在线| 日韩亚洲精品视频| 亚洲加勒比久久88色综合| 日韩美女中文字幕| 在线精品国产欧美| 亚洲影视九九影院在线观看| 国产suv精品一区二区| 国产精品视频内| 国产精品91久久久| 26uuu日韩精品一区二区| 国产一级揄自揄精品视频| 欧美激情性做爰免费视频| 国产日韩中文在线| 精品国模在线视频| 欧美在线视频a| 久久99国产精品久久久久久久久| 欧美制服第一页| 黑人巨大精品欧美一区二区三区| 久久天天躁狠狠躁夜夜av| 日韩av理论片| 青青草原成人在线视频| 欧美日韩国产二区| 欧美精品电影免费在线观看| 青青草99啪国产免费| 国产亚洲一区二区在线| 亚洲第一页中文字幕| 国产成人精品免高潮在线观看| 97人人模人人爽人人喊中文字| 日本中文字幕成人| 亚洲视频网站在线观看| 久久躁日日躁aaaaxxxx| 欧美激情xxxx| 97国产一区二区精品久久呦| 国产精品久久久久高潮| 亚洲天堂av女优| 欧洲成人午夜免费大片| 色婷婷亚洲mv天堂mv在影片| 91久久精品国产91久久| 成人网页在线免费观看| 日韩精品极品在线观看播放免费视频| 亚洲精品xxx| 亚洲人永久免费| 国产成人激情小视频| 欧美日韩在线视频一区| 97在线免费视频| 夜夜狂射影院欧美极品| 亚洲国产精彩中文乱码av在线播放| 日韩亚洲国产中文字幕| 亚洲色图色老头| 91九色国产在线| 国产午夜精品视频免费不卡69堂| 国产精品成熟老女人| 国产成人精品亚洲精品| 91久久国产精品| 91欧美精品成人综合在线观看| 精品久久久久久久久中文字幕| 在线播放国产一区中文字幕剧情欧美| 亚洲资源在线看| 国产精自产拍久久久久久蜜| 中文在线资源观看视频网站免费不卡| 欧美高清电影在线看| 亚洲精品久久7777777| 国产日产亚洲精品| 色婷婷**av毛片一区| 国产成人免费91av在线| 亚洲精品乱码久久久久久金桔影视| 成人免费大片黄在线播放| 日韩av在线直播| 久久久久久国产精品三级玉女聊斋| 日韩电影在线观看永久视频免费网站| 亚洲电影av在线| 欧美在线播放视频| 国产69精品久久久久9| 91成人天堂久久成人| 亚洲大胆人体在线| 久久久精品电影| 岛国av一区二区| 最近中文字幕日韩精品| 欧美午夜精品久久久久久久| 日韩精品在线视频美女| 亚洲r级在线观看| 欧美性受xxxx黑人猛交| 国产精品专区第二|