日韩性视频-久久久蜜桃-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 主席树的全部內容,希望文章能夠幫你解決所遇到的問題。

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