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

题面

BZOJ

洛谷

题解

送分题???

预处理一下\(k\)次方的前缀和。

然后求个\(LCA\)就做完了?、、、

  1. #include<iostream>
  2. #include<cstdio>
  3. using namespace std;
  4. #define MOD 998244353
  5. #define MAX 300300
  6. inline int read()
  7. {
  8. int x=0;bool t=false;char ch=getchar();
  9. while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
  10. if(ch=='-')t=true,ch=getchar();
  11. while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
  12. return t?-x:x;
  13. }
  14. int s[51][MAX];
  15. int n,Q;
  16. struct Line{int v,next;}e[MAX<<1];
  17. int h[MAX],cnt=1;
  18. inline void Add(int u,int v){e[cnt]=(Line){v,h[u]};h[u]=cnt++;}
  19. int dep[MAX],top[MAX],fa[MAX],size[MAX],hson[MAX];
  20. void dfs1(int u,int ff)
  21. {
  22. fa[u]=ff;dep[u]=dep[ff]+1;size[u]=1;
  23. for(int i=h[u];i;i=e[i].next)
  24. {
  25. int v=e[i].v;if(v==ff)continue;
  26. dfs1(v,u);size[u]+=size[v];
  27. if(size[v]>size[hson[u]])hson[u]=v;
  28. }
  29. }
  30. void dfs2(int u,int tp)
  31. {
  32. top[u]=tp;if(hson[u])dfs2(hson[u],tp);
  33. for(int i=h[u];i;i=e[i].next)
  34. if(e[i].v!=fa[u]&&e[i].v!=hson[u])
  35. dfs2(e[i].v,e[i].v);
  36. }
  37. int LCA(int u,int v)
  38. {
  39. while(top[u]^top[v])dep[top[u]]<dep[top[v]]?v=fa[top[v]]:u=fa[top[u]];
  40. return dep[u]<dep[v]?u:v;
  41. }
  42. int main()
  43. {
  44. n=read();
  45. for(int i=1;i<n;++i)
  46. {
  47. int u=read(),v=read();
  48. Add(u,v);Add(v,u);
  49. }
  50. dep[0]=-1;dfs1(1,0);dfs2(1,1);dep[0]=0;
  51. for(int i=1;i<=n;++i)
  52. for(int j=1,pw=1;j<=50;++j)
  53. s[j][i]=pw=1ll*pw*i%MOD;
  54. for(int j=1;j<=50;++j)
  55. for(int i=1;i<=n;++i)
  56. s[j][i]=(s[j][i]+s[j][i-1])%MOD;
  57. Q=read();
  58. while(Q--)
  59. {
  60. int u=read(),v=read(),k=read(),lca=LCA(u,v),ans=0;
  61. ans=(s[k][dep[u]]+s[k][dep[v]])%MOD;
  62. ans=(ans+MOD-s[k][dep[lca]])%MOD;
  63. ans=(ans+MOD-s[k][dep[fa[lca]]])%MOD;
  64. printf("%d\n",ans);
  65. }
  66. return 0;
  67. }

【BZOJ5293】[BJOI2018]求和(前缀和,LCA)的更多相关文章

  1. bzoj5293: [Bjoi2018]求和

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

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

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

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

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

  4. [BZOJ5293][BJOI2018]求和(倍增)

    裸的树上倍增. #include<cstdio> #include<cstring> #include<algorithm> #define rep(i,l,r) ...

  5. P4427 [BJOI2018]求和

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

  6. LCA+差分【p4427】[BJOI2018]求和

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

  7. Luogu P4427 [BJOI2018]求和

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

  8. 【刷题】BZOJ 5293 [Bjoi2018]求和

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

  9. NOIP2015运输计划(树上前缀和+LCA+二分)

    Description 公元 2044 年,人类进入了宇宙纪元. L 国有 n 个星球,还有 n−1 条双向航道,每条航道建立在两个星球之间,这 n−1 条航道连通了 L 国的所有星球. 小 P 掌管 ...

随机推荐

  1. C#设计模式之4:装饰者模式

    装饰者模式 背景是有一家星巴兹咖啡店,由于客源充足,所以决定重新设计他们的收费系统,以前的收费系统中只定义了一个表示饮料的Beverage的基类,它里面定义了一个Cost的方法用来计算饮料的花费,但是 ...

  2. oracle创建表空间、创建用户、授权角色和导入导出用户数据

    使用数据库管理员身份登录 -- log as sysdba sqlplus / as sysdba; 创建临时表空间 -- create temporary tablespace create tem ...

  3. java代理:静态代理和动态代理

    一.Java中有一个设计模式是代理模式 代理模式是常用的Java设计模式,特征是代理类与委托类有相同的接口,代理类主要负责为委托类预处理消息.过滤消息.把消息转发给委托类,以及事后处理消息等. 代理类 ...

  4. PHP中对象是按值传递还是按引用传递?

    1.首先,什么是按值传递和按引用传递? 按值传递就是仅仅把值传递过去,相当于传递的是值的拷贝,而按引用传递传递的是内存的地址. 在 PHP5 中,如果按引用传递,就是将 zval 的地址赋给另一个变量 ...

  5. Azure系列2.1.9 —— CloudBlob

    (小弟自学Azure,文中有不正确之处,请路过各位大神指正.) 网上azure的资料较少,尤其是API,全是英文的,中文资料更是少之又少.这次由于公司项目需要使用Azure,所以对Azure的一些学习 ...

  6. VSC软件快捷键

    Shift + Alt + F  格式化 Ctrl+Shift+P, F1显示命令面板 Ctrl+P快速打开,进入File… Ctrl + Shift + N新窗口/实例 Ctrl + Shift + ...

  7. 第四周作业&&结对编程

    1. 结对编程. 本周开始,和我结对编程的小伙伴是齐嘉亮(博客:http://www.cnblogs.com/zhengrui0452/). 因为这周需要发布四人团队项目的alpha版本,刚好我和亮哥 ...

  8. python之路--面向对象-成员

    一 . 成员 在类中你能写的所有内容都是类的成员 class 类名: # 方法 def__init__(self, 参数1, 参数2...): # 属性变量 self.属性1 = 参数1 self.属 ...

  9. Sqoop 使用详解(内含对官方文档的解析)

    Sqoop 是 Cloudera 公司创造的一个数据同步工具,现在已经完全开源了. 目前已经是 hadoop 生态环境中数据迁移的首选,另外还有 ali 开发的 DataX 属于同类型工具,由于社区的 ...

  10. 引入kaptcha实现验证码验证

    1.导入jar包, 可以选择去 https://mvnrepository.com 里面搜索,也可以直接复制下面的代码 2.复制到maven配置文件pom.xml中并保存 <dependency ...