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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

HDU 2852 KiKi's K-Number 主席树

發布時間:2025/3/15 编程问答 16 豆豆
生活随笔 收集整理的這篇文章主要介紹了 HDU 2852 KiKi's K-Number 主席树 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題意:

要求維護一個數據結構,支持下面三種操作:

  • \(0 \, e\):插入一個值為\(e\)的元素
  • \(1 \, e\):刪除一個值為\(e\)的元素
  • \(2 \, a \, k\):查詢比\(a\)大的數中的第\(k\)

分析:

因為插入的數在\(10^5\)內,所以不需要離散化。
維護一棵主席樹,每次插入或者刪除元素都新建一棵主席樹。
對于查詢操作,先查詢不超過\(a\)的元素的個數\(cnt\),然后再查詢序列中第\(cnt+k\)小即可。

#include <cstdio> #include <cstring> #include <algorithm> using namespace std;const int maxn = 100000 + 10; const int maxnode = (maxn << 5);int n;int sz, root[maxn]; int lch[maxnode], rch[maxnode], sum[maxnode];int update(int pre, int L, int R, int p, int v) {int rt = ++sz;sum[rt] = sum[pre] + v;if(L < R) {int M = (L + R) / 2;if(p <= M) { rch[rt] = rch[pre]; lch[rt] = update(lch[pre], L, M, p, v); }else { lch[rt] = lch[pre]; rch[rt] = update(rch[pre], M+1, R, p, v); }}return rt; }int Qcnt(int rt, int L, int R, int p) {if(L == R) return sum[rt];int M = (L + R) / 2;if(p <= M) return Qcnt(lch[rt], L, M, p);else return Qcnt(rch[rt], M+1, R, p); }int Qsum(int rt, int L, int R, int p) {if(L == R) return sum[rt];int M = (L + R) / 2;if(p <= M) return Qsum(lch[rt], L, M, p);else return sum[lch[rt]] + Qsum(rch[rt], M+1, R, p); }int kth(int rt, int L, int R, int k) {if(L == R) return L;int num = sum[lch[rt]];int M = (L + R) / 2;if(num >= k) return kth(lch[rt], L, M, k);else return kth(rch[rt], M+1, R, k-num); }int main() {while(scanf("%d", &n) == 1) {int cnt = 0;sz = 0;while(n--) {int op, a; scanf("%d%d", &op, &a);if(op == 0) {cnt++;root[cnt] = update(root[cnt-1], 1, maxn, a, 1);} else if(op == 1) {if(!Qcnt(root[cnt], 1, maxn, a)) puts("No Elment!");else {cnt++;root[cnt] = update(root[cnt-1], 1, maxn, a, -1);}} else {int b; scanf("%d", &b);int k = Qsum(root[cnt], 1, maxn, a);//printf("k1 = %d\n", k);k += b;//printf("k2 = %d\n", k);if(k > sum[root[cnt]]) { puts("Not Find!"); continue; }printf("%d\n", kth(root[cnt], 1, maxn, k));}}}return 0; }

轉載于:https://www.cnblogs.com/AOQNRMGYXLMV/p/5343355.html

總結

以上是生活随笔為你收集整理的HDU 2852 KiKi's K-Number 主席树的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 日本少妇中文字幕 | 蜜桃臀一区二区三区 | 伊人久久久久久久久久久久久 | 日韩在线观看精品 | 国产乱码精品一区二区三区亚洲人 | 国产富婆一级全黄大片 | 国产一区不卡在线观看 | www国产免费 | 国产亚洲成av人在线观看导航 | 国模无码视频一区二区三区 | 沈樵精品国产成av片 | 亚洲中文字幕无码一区二区三区 | 日本肉体xxxⅹ裸体交 | 羞羞草影院 | 91av国产精品| 久久无码视频网站 | 极品销魂美女一区二区三区 | 日本69视频 | 国产精品99久久久久久大便 | 青青草视频在线看 | 成人自拍av | 少妇欧美激情一区二区三区 | 国产亚洲一区二区三区四区 | 国模大胆一区二区三区 | 亚洲中文字幕一区 | 日本成人午夜 | av高清在线免费观看 | 嫩草影院懂你的 | 波多野结衣亚洲一区 | 中文字幕――色哟哟 | 国产玖玖在线 | 欧美黑人精品一区二区不卡 | 美女被c出白浆 | 进去里视频在线观看 | 色哟哟免费视频 | 国产精品激情 | av毛片在线看| 国产一二 | 午夜影院在线免费观看 | 中文字幕一区二区三区手机版 | 污视频在线网站 | 亚洲综合五月天婷婷丁香 | 一级日批片| 香蕉二区 | 欧美成人综合一区 | 久久久久久久91 | 欧美韩日 | 久久精品99久久久久久久久 | 婷婷色图| 女人18毛片毛片毛片毛片区二 | 精品国产99| 日本偷拍一区 | 国内爆初菊对白视频 | 一二三四av| 日本污网站 | 国产一卡二卡在线播放 | 中文字幕高清在线观看 | av视屏在线| 亚洲欧美日韩在线看 | 成人做爰视频www | 蜜臀av性久久久久蜜臀aⅴ四虎 | 99精品视频99 | 国产青青草在线 | 中文字幕在线观 | 淫人网| 成人黄色激情小说 | 香蕉福利| 99色图| 男人和女人日批视频 | 色播99| 黑白配av | 偷拍老头老太高潮抽搐 | 亚洲视频在线免费播放 | 青在线视频 | 特级毛片a | 国产一级特黄毛片 | 欧美一区二区 | 超碰操 | 久久免费av | 丰满岳妇乱一区二区三区 | 一级黄色片在线观看 | 天天激情站 | 亚洲性事| 欧美少妇一区二区三区 | 麻豆视频在线观看免费 | av综合一区 | 少女情窦初开的第4集在线观看 | 一卡二卡在线观看 | 日韩av一区二区在线观看 | 成年人免费网 | av在线免费网站 | www夜插内射视频网站 | 毛片网站在线 | 日韩无码精品一区二区 | 韩国bj大尺度vip福利网站 | 日韩激情网址 | 中文无码一区二区三区在线观看 | 精品欧美一区二区三区久久久 | 亚洲福利专区 |