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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

P3899 [湖南集训]谈笑风生(线段树合并)

發(fā)布時(shí)間:2023/12/4 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 P3899 [湖南集训]谈笑风生(线段树合并) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

P3899 [湖南集訓(xùn)]談笑風(fēng)生

給定一顆以111號(hào)節(jié)點(diǎn)為根的樹,如果a≠ba \neq ba?=b,且aaabbb的祖先,則aaabbb更厲害,如果a≠ba \neq ba?=b,且dis(a,b)≤xdis(a, b) \leq xdis(a,b)xxxx為給定的一個(gè)數(shù),則a,ba, ba,b緊鄰。

現(xiàn)有mmm次詢問,每次詢問給定p,kp, kp,k,為存在多少個(gè)三元組(p,b,c)(p, b, c)(p,b,c)滿足一下條件:

  • p,bp, bp,b都比ccc厲害。
  • p,bp, bp,b彼此緊鄰對(duì)于給定的常數(shù)kkk。

因?yàn)?span id="ozvdkddzhkzd" class="katex--inline">p,bp, bp,b都比ccc更厲害,則p,bp, bp,b都是ccc的祖先,分情況討論:

  • pppbbb的祖先

    只要滿足bbbppp的子樹中且,cccbbb的子樹中即可。

  • bbbppp的祖先

    bbb一定在1?>p1-> p1?>p的路徑上,且cccppp的子樹中。

線段樹合并搞一搞,在線,離線都可,復(fù)雜度O(nlog?n)O(n \log n)O(nlogn)。

#include <bits/stdc++.h>using namespace std;const int N = 3e5 + 10;int head[N], to[N << 1], nex[N << 1], cnt = 1;int root[N], ls[N << 5], rs[N << 5], num;int dep[N], sz[N], n, m;long long sum[N << 5];long long ans[N];vector<pair<int, int>> query[N];void add(int x, int y) {to[cnt] = y;nex[cnt] = head[x];head[x] = cnt++; }int merge(int x, int y, int l, int r) {if (!x || !y) {return x | y;}if (l == r) {sum[x] += sum[y];return x;}int mid = l + r >> 1;ls[x] = merge(ls[x], ls[y], l, mid);rs[x] = merge(rs[x], rs[y], mid + 1, r);sum[x] = sum[ls[x]] + sum[rs[x]];return x; }void update(int &rt, int l, int r, int x, int v) {if (!rt) {rt = ++num;}sum[rt] += v;if (l == r) {return ;}int mid = l + r >> 1;if (x <= mid) {update(ls[rt], l, mid, x, v);}else {update(rs[rt], mid + 1, r, x, v);} }long long ask(int rt, int l, int r, int L, int R) {if (l >= L && r <= R) {return sum[rt];}long long ans = 0;int mid = l + r >> 1;if (L <= mid) {ans += ask(ls[rt], l, mid, L, R);}if (R > mid) {ans += ask(rs[rt], mid + 1, r, L, R);}return ans; }void dfs(int rt, int fa) {dep[rt] = dep[fa] + 1, sz[rt] = 1;for (int i = head[rt]; i; i = nex[i]) {if (to[i] == fa) {continue;}dfs(to[i], rt);sz[rt] += sz[to[i]];root[rt] = merge(root[rt], root[to[i]], 1, n);}for (auto it : query[rt]) {int id = it.first, k = it.second;ans[id] = ask(root[rt], 1, n, dep[rt], min(dep[rt] + k, n));ans[id] += 1ll * (dep[rt] - max(1, dep[rt] - k)) * (sz[rt] - 1);}update(root[rt], 1, n, dep[rt], sz[rt] - 1); }int main() {// freopen("in.txt", "r", stdin);// freopen("out.txt", "w", stdout);scanf("%d %d", &n, &m);for (int i = 1, x, y; i < n; i++) {scanf("%d %d", &x, &y);add(x, y);add(y, x);}for (int i = 1, x, k; i <= m; i++) {scanf("%d %d", &x, &k);query[x].push_back({i, k});}dfs(1, 0);for (int i = 1; i <= m; i++) {printf("%lld\n", ans[i]);}return 0; }

總結(jié)

以上是生活随笔為你收集整理的P3899 [湖南集训]谈笑风生(线段树合并)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。