[luogu P2633] Count on a tree

题目描述

给定一棵N个节点的树,每个点有一个权值,对于M个询问(u,v,k),你需要回答u xor lastans和v这两个节点间第K小的点权。其中lastans是上一个询问的答案,初始为0,即第一个询问的u是明文。

输入输出格式

输入格式:

第一行两个整数N,M。

第二行有N个整数,其中第i个整数表示点i的权值。

后面N-1行每行两个整数(x,y),表示点x到点y有一条边。

最后M行每行两个整数(u,v,k),表示一组询问。

输出格式:

M行,表示每个询问的答案。

输入输出样例

输入样例#1: 复制

  1. 8 5
  2. 105 2 9 3 8 5 7 7
  3. 1 2
  4. 1 3
  5. 1 4
  6. 3 5
  7. 3 6
  8. 3 7
  9. 4 8
  10. 2 5 1
  11. 0 5 2
  12. 10 5 3
  13. 11 5 4
  14. 110 8 2
输出样例#1: 复制

  1. 2
  2. 8
  3. 9
  4. 105
  5. 7

说明

HINT:

N,M<=100000

暴力自重。。。

来源:bzoj2588 Spoj10628.

本题数据为洛谷自造数据,使用CYaRon耗时5分钟完成数据制作。

主席树的变形,离散后,对于每个点u构造一棵新的主席树都建立在以fa[u][0]构造的主席树的基础之上。

其中,要按照dfs序来造,才能保证正确性。(用bfs序当然也可以咯)

然后询问两个点(x,y)时,根据主席树可加减的性质,只要在tree[x]+tree[y]-tree[lca(x,y)]-tree[fa[lca(x,y)]]这棵树上查询就可以了。

注意强制在线。

code:

  1. #include <cstdio>
  2. #include <cstring>
  3. #include <algorithm>
  4. #include <tr1/unordered_map>
  5. #define ms(a,x) memset(a,x,sizeof a)
  6. using namespace std;
  7. void OJ() {
  8. #ifndef ONLINE_JUDGE
  9. freopen("in.txt","r",stdin);
  10. freopen("out.txt","w",stdout);
  11. #endif
  12. }
  13.  
  14. namespace fastIO {
  15. #define gec(c) getchar(c)
  16. #define puc(c) putchar(c)
  17. char ch;
  18. inline int read() {
  19. ,f=; ch=getchar();
  20. ') {
  21. if (ch=='-') f=-f;
  22. ch=gec();
  23. }
  24. ') {
  25. x=(x<<)+(x<<)+ch-';
  26. ch=getchar();
  27. }
  28. return x*f;
  29. }
  30. ];
  31. template <class T> inline void write(T x) {
  32. ) {
  33. puc('); return;
  34. }
  35. ) x=-x,puc('-');
  36. ; x; x/=) nnn[++ttt]=x%;
  37. );
  38. }
  39. inline void newline() {
  40. puc('\n');
  41. }
  42. } using namespace fastIO;
  43.  
  44. ;
  45. int n,m,cnt,b[N];
  46. ],son[N<<];
  47. ],dfn[N],rel[N],clo;
  48. tr1::unordered_map <int,int> ref;
  49. struct data {
  50. int x,i;
  51. } a[N];
  52. inline bool cmp_x (const data &u,const data &v) {
  53. return u.x<v.x;
  54. }
  55. inline bool cmp_i (const data &u,const data &v) {
  56. return u.i<v.i;
  57. }
  58. struct node {
  59. node* l,* r; int v;
  60. node () {
  61. l=r=,v=;
  62. }
  63. } *r[N];
  64. #define M ((l)+(r)>>1)
  65. inline void setup (node* &c,int l,int r) {
  66. c=new node();
  67. if (l==r) return;
  68. setup(c->l,l,M),setup(c->r,M+,r);
  69. }
  70. inline void insert (node* &c,int l,int r,int x,node* his) {
  71. c=new node();
  72. c->l=his->l,c->r=his->r,c->v=his->v+;
  73. if (l==r) return;
  74. if (x<=M) insert(c->l,l,M,x,his->l);
  75. ,r,x,his->r);
  76. }
  77. inline ) {
  78. if (l==r) return b[l];
  79. v+=x->l->v,v+=y->l->v;
  80. v-=z->l->v,v-=o->l->v;
  81. if (k<=v) return reply(x->l,y->l,z->l,o->l,l,M,k);
  82. ,r,k-v);
  83. }
  84. void add (int x,int y) {
  85. nxt[++tot]=lnk[x],lnk[x]=tot,son[tot]=y;
  86. }
  87. void dfs (int x,int p) {
  88. dep[x]=dep[p]+,fa[x][]=p,rel[dfn[x]=++clo]=x;
  89. ; j<=; ++j) fa[x][j]=fa[fa[x][j-]][j-];
  90. for (int j=lnk[x]; j; j=nxt[j]) {
  91. if (son[j]!=p) dfs(son[j],x);
  92. }
  93. }
  94. int lca (int x,int y) {
  95. if (dep[x]<dep[y]) swap(x,y);
  96. ) ;
  97. int dif=dep[x]-dep[y];
  98. ; ~j; --j)
  99. <<j)) x=fa[x][j];
  100. if (x==y) return x;
  101. ; ~j; --j)
  102. if (fa[x][j]!=fa[y][j]) x=fa[x][j],y=fa[y][j];
  103. ];
  104. }
  105. int main() {
  106. OJ(); ;
  107. n=read(),m=read();
  108. ; i<=n; ++i) a[i].x=read();
  109. ; i<n; ++i) {
  110. x=read(),y=read();
  111. add(x,y),add(y,x);
  112. }
  113. dep[]=,dfn[]=,dfs(,);
  114. ; i<=n; ++i) a[i].i=dfn[i];
  115. sort(a+,a++n,cmp_x);
  116. b[cnt=].x]=]=a[].x;
  117. ; i<=n; i++)
  118. ].x) b[ref[a[i].x]=++cnt]=a[i].x;
  119. sort(a+,a++n,cmp_i);
  120. setup(r[],,cnt);
  121. ; i<=n; ++i) insert(r[i],,cnt,]]]);
  122. ; i<=m; ++i) {
  123. x=read(),x^=lastans,y=read(),z=lca(x,y),o=fa[z][],k=read();
  124. x=dfn[x],y=dfn[y],z=dfn[z],o=dfn[o];
  125. write(lastans=reply(r[x],r[y],r[z],r[o],,cnt,k));
  126. if (i^m) newline();
  127. }
  128. ;
  129. }

[luogu P2633] Count on a tree的更多相关文章

  1. 主席树 || 可持久化线段树 || LCA || BZOJ 2588: Spoj 10628. Count on a tree || Luogu P2633 Count on a tree

    题面: Count on a tree 题解: 主席树维护每个节点到根节点的权值出现次数,大体和主席树典型做法差不多,对于询问(X,Y),答案要计算ans(X)+ans(Y)-ans(LCA(X,Y) ...

  2. 洛谷 P2633 Count on a tree

    P2633 Count on a tree 题目描述 给定一棵N个节点的树,每个点有一个权值,对于M个询问(u,v,k),你需要回答u xor lastans和v这两个节点间第K小的点权.其中last ...

  3. 洛谷P2633 Count on a tree(主席树上树)

    题目描述 给定一棵N个节点的树,每个点有一个权值,对于M个询问(u,v,k),你需要回答u xor lastans和v这两个节点间第K小的点权.其中lastans是上一个询问的答案,初始为0,即第一个 ...

  4. 洛谷 P2633 Count on a tree 主席树

    在一棵树上,我们要求点 $(u,v)$ 之间路径的第$k$大数. 对于点 $i$  ,建立 $i$  到根节点的一棵前缀主席树. 简单容斥后不难得出结果为$sumv[u]+sumv[v]−sumv[l ...

  5. 洛谷 P2633 Count on a tree 题解

    题面 对于每个点建立一颗主席树: 然后按照树上差分的思想统计主席树的前缀和: lca+主席树+前向星存表就可以了: #include <bits/stdc++.h> #define inc ...

  6. 洛谷P2633 Count on a tree(主席树,倍增LCA)

    洛谷题目传送门 题目大意 就是给你一棵树,每个点都有点权,每次任意询问两点间路径上点权第k小的值(强制在线). 思路分析 第k小......又是主席树了.但这次变成树了,无法直接维护前缀和. 又是树上 ...

  7. ☆ [洛谷P2633] Count on a tree 「树上主席树」

    题目类型:主席树+\(LCA\) 传送门:>Here< 题意:给出一棵树.每个节点有点权.问某一条路径上排名第\(K\)小的点权是多少 解题思路 类似区间第\(K\)小,但放在了树上. 考 ...

  8. 洛谷P2633 Count on a tree 主席树

    传送门:主席树 解题报告: 传送门! umm这题我还麻油开始做 所以 先瞎扯一波我的想法,如果错了我就当反面教材解释这种典型错误,对了我就不管了QwQ 就直接dfs,在dfs的过程中建树 然后就直接查 ...

  9. P2633 Count on a tree

    思路 运用树上差分的思想,转化成一个普通的主席树模型即可求解 代码 #include <cstdio> #include <algorithm> #include <cs ...

随机推荐

  1. Python魔法方法详解

      魔法方法 含义   基本的魔法方法 __new__(cls[, ...]) 1.__new__是在一个对象实例化的时候所调用的第一个方法 2.它的第一个参数是这个类,其他的参数是用来直接传递给__ ...

  2. python 开发练习之 监控

    本节内容 为什么要做监控? 常用监控系统设计讨论 监控系统架构设计 监控表结构设计 为什么要做监控? –熟悉IT监控系统的设计原理 –开发一个简版的类Zabbix监控系统 –掌握自动化开发项目的程序设 ...

  3. 解决ssh连接问题2

    ssh远程出现问题shell request failed on channel 0 1.修改/etc/security/limits.conf ssh_exchange_identification ...

  4. FairyGUI TextField

    记录一个在使用FairyGUI的TextField时遇到的坑. TextField有一个文本模板功能,可以实现类似占位符的功能,如:{ number = 0 },然后我们可以在脚本中修改number的 ...

  5. VB代码收集

    1.随机获取5位验证码? 需求: 创建一个Label1:名称为随机验证码生成 创建一个Label2:名称为为空,属性BorderStyle=1 创建一个CommandButton:名称为获取随机码 代 ...

  6. 搭建Flutter-iOS开发环境

    https://www.jianshu.com/p/b50a92afbef1 1.获取Flutter工程 git clone -b beta https://github.com/flutter/fl ...

  7. InvalidArgumentError: ConcatOp : Dimensions of inputs should match: shape[0] = [1,136,240,64] vs. shape[1] = [1,135,240,64]

    初始输入图片大小为1600*1200,设置的输入网络的最大测试图片大小为1600*1200相当于scale =1 ,运行没有问题.之后输入图片大小为1920*1080,测试图片大小为1920*1080 ...

  8. ASP.NET Core API 接收参数去掉烦人的 [FromBody]

    在测试ASP.NET Core API 项目的时候,发现后台接口参数为类型对象,对于PostMan和Ajax的Post方法传Json数据都获取不到相应的值,后来在类型参数前面加了一个[FromBody ...

  9. 深度学习环境搭建(ubuntu16.04+Titan Xp安装显卡驱动+Cuda9.0+cudnn+其他软件)

    一.硬件环境 ubuntu 16.04LTS + windows10 双系统 NVIDIA TiTan XP 显卡(12G) 二.软件环境 搜狗输入法 下载地址 显卡驱动:LINUX X64 (AMD ...

  10. 2019金融科技风往哪儿吹?蚂蚁金服联合20余家金融机构预测新年热点:5G、区块链上榜

    2019年,金融科技的风向标在哪里?哪些板块成新宠,哪些科技成潮流? 1月4日,蚂蚁金服ATEC城市峰会在上海举行.大会上,蚂蚁金服与20余家金融机构一起预测了2019年金融科技的发展. “未来金融会 ...