日本搞逼视频_黄色一级片免费在线观看_色99久久_性明星video另类hd_欧美77_综合在线视频

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > 互聯網 > POJ 1442 Black Box treap求區間第k大

POJ 1442 Black Box treap求區間第k大

來源:程序員人生   發布時間:2014-09-09 05:20:08 閱讀次數:3456次

題目來源:POJ 1442 Black Box

題意:輸入xi 輸出前xi個數的第i大的數

思路:試了下自己的treap模版

#include <cstdio> #include <cstring> #include <cstdlib> #include <ctime> using namespace std; struct Node { Node *ch[2]; int r; int v; int s; Node(){} Node(int v): v(v) { ch[0] = ch[1] = NULL; r = rand(); s = 1; } bool operator < (const Node& rhs) const{ return r < rhs.r; } int cmp(int x) const{ if(x == v) return -1; return x < v ? 0 : 1; } void maintain(){ s = 1; if(ch[0] != NULL) s += ch[0]->s; if(ch[1] != NULL) s += ch[1]->s; } }; void rotate(Node* &o, int d){ Node* k = o->ch[d^1]; o->ch[d^1] = k->ch[d]; k->ch[d] = o; o->maintain(); k->maintain(); o = k; } void insert(Node* &o, int x){ if(o == NULL){ o = new Node(x); } else{ int d = (x < o->v ? 0 : 1); insert(o->ch[d], x); if((o->ch[d]->r) > (o->r)) rotate(o, d^1); } o->maintain(); } void remove(Node* &o, int x){ int d= o->cmp(x); if(d == -1){ Node* u = o; if(o->ch[0] != NULL && o->ch[1] != NULL){ int d2 = (o->ch[0] > o->ch[1] ? 1 : 0); rotate(o, d2); remove(o->ch[d2], x); } else{ if(o->ch[0] == NULL) o = o->ch[1]; else o = o->ch[0]; delete u; } } else remove(o->ch[d], x); if(o != NULL) o->maintain(); } int kth(Node* o, int k){ if(o == NULL || k <= 0 || k > o->s) return 0; int s = (o->ch[0] == NULL ? 0 : o->ch[0]->s); if(k == s+1) return o->v; else if(k <= s) return kth(o->ch[0], k); else return kth(o->ch[1], k-s-1); } void removetree(Node* &x){ if(x->ch[0] != NULL) removetree(x->ch[0]); if(x->ch[1] != NULL) removetree(x->ch[1]); delete x; x = NULL; } int n, m, a[30010]; Node *rt = NULL; int main() { while(scanf("%d %d", &n, &m) != EOF) { srand(time(0)); for(int i = 1; i <= n; i++) scanf("%d", &a[i]); int l = 1; for(int i = 1; i <= m; i++) { int x; scanf("%d", &x); while(l <= x) { insert(rt, a[l]); l++; } printf("%d ", kth(rt, i)); } //removetree(rt); } return 0; }


生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 欧美激情综合五月色丁香小说 | 黄网站在线免费看 | 日韩精品在线一区二区 | 欧美日韩国产精品 | 久久精品观看 | 一区二区三区在线看 | 欧美日本高清 | 不卡的av网站 | 国产日| 精品久久久久久久久久ntr影视 | 欧美在线观看一区 | 欧美一区二区三区免费 | 嫩草嫩草嫩草嫩草嫩草 | 欧美日韩成人在线观看 | 欧美日韩国产亚洲乱码字幕 | 久久福利免费视频 | 欧美成人二区 | 嫩草在线看| 免费a在线观看 | 欧美偷拍视频 | 九九免费视频 | 亚洲国产aⅴ成人精品无吗 国产一区免费在线观看 | 国产精品日韩欧美一区二区 | 国产综合久久 | 久久久91精品国产一区二区三区 | 亚洲精品二| 国产成人精品亚洲777人妖 | 国产精品视频久久 | 三级福利视频 | 国产精品一二三 | www伊人 | 一个色综合视频 | 日韩伦理一区二区 | 日韩精品中文字幕一区二区三区 | 亚洲成人精品 | 国产欧美日本在线 | 亚洲精品视频一区二区三区 | 亚洲欧美片 | 精品免费国产 | 99精品国产高清在线观看 | 亚洲一区在线电影 |