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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

BZOJ 1878 HH的项链 | 主席树

發布時間:2023/12/10 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 BZOJ 1878 HH的项链 | 主席树 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題意

詢問區間有多少不同的數。

題解

和Luogu 1903一樣,這道題也是用pre數組來求區間不同數的個數,這里pre[i]表示a[i]上一次出現的位置 +1,詢問相當于查詢區間內有多少pre小于等于左端點。

#include <cstdio> #include <cstring> #include <algorithm> #include <set> using namespace std; typedef long long ll; #define space putchar(' ') #define enter putchar('\n') template <class T> void read(T &x){char c;bool op = 0;while(c = getchar(), c < '0' || c > '9')if(c == '-') op = 1;x = c - '0';while(c = getchar(), c >= '0' && c <= '9')x = x * 10 + c - '0';if(op) x = -x; } template <class T> void write(T x){if(x < 0) x = -x, putchar('-');if(x >= 10) write(x / 10);putchar('0' + x % 10); } const int N = 50005; int n, m, l, r, ans, a[N], last[1000005], pre[N]; int idx, ls[N*50], rs[N*50], data[N*50], root[N]; void build(int &k, int l, int r){k = ++idx;if(l == r) return;int mid = (l + r) >> 1;build(ls[k], l, mid);build(rs[k], mid + 1, r); } void change(int old, int &k, int l, int r, int p, int x){k = ++idx;ls[k] = ls[old], rs[k] = rs[old], data[k] = data[old];if(l == r) return (void)(data[k] += x);int mid = (l + r) >> 1;if(p <= mid) change(ls[old], ls[k], l, mid, p, x);else change(rs[old], rs[k], mid + 1, r, p, x);data[k] = data[ls[k]] + data[rs[k]]; } int query(int old, int k, int l, int r, int ql, int qr){if(ql <= l && qr >= r) return data[k] - data[old];int mid = (l + r) >> 1, ret = 0;if(ql <= mid) ret += query(ls[old], ls[k], l, mid, ql, qr);if(qr > mid) ret += query(rs[old], rs[k], mid + 1, r, ql, qr);return ret; } int main(){read(n);build(root[0], 1, n);for(int i = 1; i <= n; i++){read(a[i]);pre[i] = last[a[i]] + 1;last[a[i]] = i;change(root[i - 1], root[i], 1, n, pre[i], 1);}read(m);while(m--){read(l), read(r);write(query(root[l - 1], root[r], 1, n, 1, l)), enter;}return 0; }

轉載于:https://www.cnblogs.com/RabbitHu/p/BZOJ1878.html

總結

以上是生活随笔為你收集整理的BZOJ 1878 HH的项链 | 主席树的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 人人干人人做 | 一区二区三区视频网 | 日本三级播放 | 国产人妻一区二区三区四区五区六 | 精品人妻人人做人人爽 | 久久国产精彩视频 | 黑人巨大精品欧美黑寡妇 | 欧美电影一区二区三区 | 操操操免费视频 | 原创真实夫妻啪啪av | av一级在线观看 | 波多野结衣在线免费视频 | 日本高清视频免费看 | 天堂在线一区二区 | 天天曰天天干 | 午夜丁香婷婷 | 亚洲人妻一区二区三区 | 初音未来打屁股 | 海角国产乱辈乱精品视频 | 超碰888 | 日本三级免费看 | 一二三区在线视频 | 久久极品| 亚洲理论片 | 性欧美又大又长又硬 | 久久久毛片 | 亚洲精品天堂网 | 日日射日日操 | 狠狠干2022 | 尤物视频在线免费观看 | av中文字幕一区二区 | 国产男女无套 | 天堂一区二区三区四区 | 自拍偷拍国产 | 欧美视频日韩视频 | 日日射av| 亚洲欧美另类在线观看 | 在线播放中文字幕 | 特级新鲜大片片 | 福利视频免费看 | 男人阁久久 | 精品无码黑人又粗又大又长 | 亚洲一区二区自偷自拍 | 国产精品www色诱视频 | 18男女无套免费视频 | 成人人伦一区二区三区 | xx视频在线| 中文字幕人妻伦伦 | 狠狠网| 山村大伦淫第1部分阅读小说 | 久久国产91| 国产三区在线播放 | 久久二 | 中国黄色录像一级片 | 欧美一区二区三区四区在线 | 亚洲精品乱码久久久久久蜜桃麻豆 | 911福利视频 | 亚洲精品一线二线三线 | 伊人网在线视频观看 | 在线看黄色av | 日韩精品无码一区二区三区久久久 | 久久男人精品 | 国产三区四区视频 | 思思99re | 久久久久久久免费 | 欧美在线www| 国产v综合v亚洲欧美久久 | 五月婷婷激情综合网 | 亚洲精品视频在线 | 亚洲国产成人一区二区 | 色之久久综合 | 91免费福利视频 | 韩国伦理片在线观看 | 日韩精品免费一区二区三区 | 性欧美大战久久久久久久久 | 欧美精品久久久久 | 一本色道久久hezyo加勒比 | 亚洲人女屁股眼交6 | 免费人成在线观看网站 | 91黄色小视频 | 性色av蜜臀av色欲av | 欧美日韩在线综合 | 中文字幕在线第一页 | www中文在线 | 超碰狠狠干 | 男人激烈吮乳吃奶爽文 | 99国产超薄肉色丝袜交足 | 中文字幕毛片 | 久久艹影院| 欧美精品一区二区在线播放 | 97天天操 | 成人av电影在线播放 | 亚洲视频手机在线观看 | 国产精品无码av在线播放 | 成人精品视频网站 | 一本大道久久a久久精二百 琪琪色在线视频 | 国产午夜视频在线观看 | 九九久久精品视频 | 日本a视频在线观看 |