Description

master 对树上的求和非常感兴趣。他生成了一棵有根树,并且希望多次询问这棵树上一段路径上所有节点深度的\(k\) 次方和,而且每次的\(k\) 可能是不同的。此处节点深度的定义是这个节点到根的路径上的边数。他把这个问题交给了pupil,但pupil 并不会这么复杂的操作,你能帮他解决吗?

Input

第一行包含一个正整数\(n\),表示树的节点数。

之后\(n-1\) 行每行两个空格隔开的正整数\(i,j\),表示树上的一条连接点\(i\) 和点\(j\)的边。

之后一行一个正整数\(m\),表示询问的数量。

之后每行三个空格隔开的正整数\(i, j, k\),表示询问从点\(i\)到点\(j\) 的路径上所有节点深度的\(k\) 次方和。由于这个结果可能非常大,输出其对\(998244353\) 取模的结果。

树的节点从\(1\) 开始标号,其中\(1\) 号节点为树的根。

Output

对于每组数据输出一行一个正整数表示取模后的结果。

wa了好多次,结果发现括号匹配错了QAQ。

很明显,这题可以预处理出来\(gw[u][i]\)代表从\(1\)到\(u\)路径上点的深度的\(i\)次方的和.(这是一个前缀和.

然后在\(DFS\)的时候预处理出来倍增数组和\(gw\)数组即可.

预处理\(gw\)数组

\[gw[u][i]=gw[fa][i]+ksm(depth[u],i)
\]

然后根据差分

\[gw[x][i]+gw[y][i]-(gw[lca_{x,y}][i]+gw[father[lca_{x,y}]][i])
\]

求出\(x,y\)之间的答案即可.

后面的括号写错了,难受得一逼.QAQ

代码

  1. #include<cstdio>
  2. #include<algorithm>
  3. #include<cctype>
  4. #define mod 998244353
  5. #define int long long
  6. #define N 300008
  7. #define R register
  8. using namespace std;
  9. inline void in(int &x)
  10. {
  11. int f=1;x=0;char s=getchar();
  12. while(!isdigit(s)){if(s=='-')f=-1;s=getchar();}
  13. while(isdigit(s)){x=x*10+s-'0';s=getchar();}
  14. x*=f;
  15. }
  16. int n,head[N],tot;
  17. struct cod{int u,v;}edge[N<<2];
  18. inline void add(int x,int y)
  19. {
  20. edge[++tot].u=head[x];
  21. edge[tot].v=y;
  22. head[x]=tot;
  23. }
  24. int depth[N],f[N][21],gw[N][53];
  25. int q;
  26. inline int ksm(int x,int y)
  27. {
  28. R int res=1;
  29. for(;y;y>>=1,x=x%mod*x%mod)
  30. if(y&1)res=res%mod*x%mod;
  31. return res;
  32. }
  33. void dfs(int u,int fa)
  34. {
  35. f[u][0]=fa;depth[u]=depth[fa]+1;
  36. for(R int i=1;(1<<i)<=depth[u];i++)
  37. f[u][i]=f[f[u][i-1]][i-1];
  38. for(R int i=1;i<=52;i++)
  39. gw[u][i]=gw[fa][i]+ksm(depth[u],i);
  40. for(R int i=head[u];i;i=edge[i].u)
  41. {
  42. if(edge[i].v==fa)continue;
  43. dfs(edge[i].v,u);
  44. }
  45. }
  46. inline int lca(int x,int y)
  47. {
  48. if(depth[x]>depth[y])swap(x,y);
  49. for(R int i=20;i>=0;i--)
  50. if(depth[x]+(1<<i)<=depth[y])
  51. y=f[y][i];
  52. if(x==y)return x;
  53. for(R int i=20;i>=0;i--)
  54. {
  55. if(f[x][i]==f[y][i])continue;
  56. x=f[x][i],y=f[y][i];
  57. }
  58. return f[x][0];
  59. }
  60. signed main()
  61. {
  62. in(n);
  63. for(R int i=1,x,y;i<n;i++)in(x),in(y),add(x,y);
  64. depth[1]=-1;dfs(1,1);in(q);
  65. for(R int i=1,x,y,k;i<=q;i++)
  66. {
  67. in(x),in(y),in(k);
  68. R int la=lca(x,y);
  69. printf("%lld\n",(((gw[x][k]+gw[y][k])%mod-(gw[la][k]+gw[f[la][0]][k])%mod)+mod)%mod);
  70. }
  71. }

LCA+差分【p4427】[BJOI2018]求和的更多相关文章

  1. P4427 [BJOI2018]求和

    P4427 [BJOI2018]求和 同[TJOI2018]教科书般的扭曲虚空 懒得写了(雾 #include<bits/stdc++.h> #define il inline #defi ...

  2. Luogu P4427 [BJOI2018]求和

    这是一道巨狗题,我已无力吐槽为什么我怎么写都不过 我们对于这种无修改的边权题目有一个经典的树上差分套路: \(ans=sum_x+sum_y-2\cdot sum_{LCA(x,y)}\) 这里的\( ...

  3. 洛谷P4427 [BJOI2018]求和

    \(\Large\textbf{Description: } \large{一颗n个节点的树,m次询问,每次查询点i到点j的路径上所有节点点深度的k次方的和并对998244353取模(1\leq n, ...

  4. 【BZOJ5293】[BJOI2018]求和(前缀和,LCA)

    [BZOJ5293][BJOI2018]求和(前缀和,LCA) 题面 BZOJ 洛谷 题解 送分题??? 预处理一下\(k\)次方的前缀和. 然后求个\(LCA\)就做完了?... #include& ...

  5. bzoj5293: [Bjoi2018]求和

    题目链接 bzoj5293: [Bjoi2018]求和 题解 暴力 对于lca为1的好坑啊.... 代码 #include<cmath> #include<cstdio> #i ...

  6. NOIP2015 运输计划(二分+LCA+差分)

    4326: NOIP2015 运输计划 Time Limit: 30 Sec  Memory Limit: 128 MBSubmit: 308  Solved: 208[Submit][Status] ...

  7. BZOJ5293:[BJOI2018]求和(LCA,差分)

    Description master 对树上的求和非常感兴趣.他生成了一棵有根树,并且希望多次询问这棵树上一段路径上所有节点深度的k  次方和,而且每次的k 可能是不同的.此处节点深度的定义是这个节点 ...

  8. BZOJ5293: [Bjoi2018]求和 树上差分

    Description master 对树上的求和非常感兴趣.他生成了一棵有根树,并且希望多次询问这棵树上一段路径上所有节点深度的k  次方和,而且每次的k 可能是不同的.此处节点深度的定义是这个节点 ...

  9. Luogu4427 [BJOI2018]求和 (树上差分)

    预处理,树上差分.注意深度减一 #include <cstdio> #include <iostream> #include <cstring> #include ...

随机推荐

  1. 【题解】AHOI2009同类分布

    好开心呀~果然只有不看题解做出来的题目才会真正的有一种骄傲与满足吧ヾ(๑╹◡╹)ノ" 实际上这题只要顺藤摸瓜就可以了.首先按照数位dp的套路,有两维想必是省不掉:1.当前dp到到的位数:2. ...

  2. MySQL:BlackHole

    MySQL:BlackHole 顾名思义BlackHole就是黑洞,只有写入没有输出.现在就来实验一下吧 首先查看一下MySQL支持的存储引擎 mysql> show engines;+---- ...

  3. UVA10480:Sabotage(最小割+输出)

    Sabotage 题目链接:https://vjudge.net/problem/UVA-10480 Description: The regime of a small but wealthy di ...

  4. linux 端口号、进程id、杀进程、查询tcp的连接(各种状态的)

    sudo netstat -antupkill -s 9 50713netstat -n | grep 61616netstat -n | awk '/^tcp/ {++S[$NF]} END {fo ...

  5. 一串跟随鼠标的DIV

    div跟随鼠标移动的函数: <!DOCTYPE HTML><html><head> <meta charset="utf-8"> & ...

  6. CSS中的@ AT规则

    大家可能在CSS中见到过字符@然后加一些关键字的用法,这种用法就称之为AT规则,在CSS中,种类还是很多的,这里总结列举下. 常规规则 所谓“常规规则”指的是语法类似下面的规则: @[KEYWORD] ...

  7. 一些常用的css片段

    1. 单行文字溢出时省略号 .test{ overflow:hidden; text-overflow:ellipsis; white-space:nowrap; } 2. 多行文字溢出时省略号 .t ...

  8. CSS学习之float解析

    转自:http://www.w3cplus.com/css/float.html 一.float是什么? float即为浮动,在CSS中的作用是使元素脱离正常的文档流并使其移动到其父元素的“最左边”或 ...

  9. bzoj4839 [Neerc2016]Abbreviation

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=4839 [题解] pkusc怎么出bzoj原题啊 字符串随便处理一下就行了,大模拟 pkusc ...

  10. jquery——通过name属性查找元素

      Js代码 : $("div[id]") 选择所有含有id属性的div元素 $("input[name='newsletter']") 选择所有的name属性 ...