Description

题库链接

给你一棵 \(n\) 个结点的有根树, \(m\) 次询问这棵树上一段路径上所有节点深度的 \(k\) 次方和。

\(1\leq n\leq 300000,1\leq k\leq 50\)

Solution

树剖之后维护 \(50\) 个前缀和数组。

只有刷水题才能维持得了生活这样子...

Code

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. const int N = 300000+5, yzh = 998244353;
  4. int gi() {
  5. int x = 0; char ch = getchar();
  6. while (ch < '0' || ch > '9') ch = getchar();
  7. while (ch >= '0' && ch <= '9') x = (x<<1)+(x<<3)+ch-48, ch = getchar();
  8. return x;
  9. }
  10. int n, m, u, v, k, sum[51][N];
  11. struct tt {int to, next; }edge[N<<1];
  12. int path[N], TP;
  13. int size[N], top[N], fa[N], dep[N], id[N], son[N], idx;
  14. void dfs1(int u, int depth, int father) {
  15. dep[u] = depth, size[u] = 1, fa[u] = father;
  16. for (int i = path[u]; i; i = edge[i].next)
  17. if (edge[i].to != father) {
  18. dfs1(edge[i].to, depth+1, u);
  19. size[u] += size[edge[i].to];
  20. if (size[edge[i].to] > size[son[u]]) son[u] = edge[i].to;
  21. }
  22. }
  23. void dfs2(int u, int tp) {
  24. top[u] = tp, id[u] = ++idx;
  25. if (son[u]) dfs2(son[u], tp);
  26. for (int i = path[u]; i; i = edge[i].next)
  27. if (edge[i].to != fa[u] && edge[i].to != son[u])
  28. dfs2(edge[i].to, edge[i].to);
  29. }
  30. void add(int u, int v) {edge[++TP] = (tt){v, path[u]}; path[u] = TP; }
  31. int cal(int u, int v, int k) {
  32. int ans = 0;
  33. while (top[u] != top[v]) {
  34. if (dep[top[u]] < dep[top[v]]) swap(u, v);
  35. (ans += (sum[k][id[u]]-sum[k][id[top[u]]-1]+yzh)%yzh) %= yzh;
  36. u = fa[top[u]];
  37. }
  38. if (dep[u] < dep[v]) swap(u, v);
  39. (ans += (sum[k][id[u]]-sum[k][id[v]-1]+yzh)%yzh) %= yzh;
  40. return ans;
  41. }
  42. void work() {
  43. n = gi();
  44. for (int i = 1; i < n; i++) {
  45. u = gi(), v = gi(); add(u, v), add(v, u);
  46. }
  47. dfs1(1, 0, 0); dfs2(1, 1);
  48. for (int i = 1; i <= n; i++)
  49. for (int j = 1, val = dep[i]; j <= 50; j++, val = 1ll*val*dep[i]%yzh)
  50. sum[j][id[i]] = val;
  51. for (int i = 1; i <= 50; i++)
  52. for (int j = 1; j <= n; j++)
  53. (sum[i][j] += sum[i][j-1]) %= yzh;
  54. m = gi();
  55. while (m--) {
  56. u = gi(), v = gi(), k = gi();
  57. printf("%d\n", cal(u, v, k));
  58. }
  59. }
  60. int main() {work(); return 0; }

[BJOI 2018]求和的更多相关文章

  1. 【BJOI 2018】 求和

    [题目链接] 点击打开链接 [算法] 预处理i^k的前缀和,对于每次询问,树上倍增即可 时间复杂度 : O(nk + mlog(n)) [代码] #include<bits/stdc++.h&g ...

  2. [BJOI 2018]染色

    题意:求01成立. 并查集维护,记录一个变量判断决策. #include<bits/stdc++.h> using namespace std; #define int long long ...

  3. luogu 4427 求和

    bjoi 2018 求和 唯一一道可能切的题一个数组还没开long long就成0分了 题目大意: 一棵有根树,并且希望多次询问这棵树上一段路径上所有节点深度的k次方和,而且每次的k可能是不同的 此处 ...

  4. luogu 4429 染色

    bjoi 2018 染色 推了个错误结论得了60分? 题目大意: 一个无重边和自环的无向图,并且对每个点分别给了一个大小为2的颜色集合,只能从这个集合中选一种颜色给这个点染色 求一个染色方案使得没有两 ...

  5. HDU 6333.Problem B. Harvest of Apples-组合数C(n,0)到C(n,m)求和-组合数学(逆元)+莫队 ((2018 Multi-University Training Contest 4 1002))

    2018 Multi-University Training Contest 4 6333.Problem B. Harvest of Apples 题意很好懂,就是组合数求和. 官方题解: 我来叨叨 ...

  6. [java大数据面试] 2018年4月百度面试经过+三面算法题:给定一个数组,求和为定值的所有组合.

    给定一个数组,求和为定值的所有组合, 这道算法题在leetcode应该算是中等偏下难度, 对三到五年工作经验主要做业务开发的同学来说, 一般较难的也就是这种程度了. 简述经过: 不算hr面,总计四面, ...

  7. HDU 6336.Problem E. Matrix from Arrays-子矩阵求和+规律+二维前缀和 (2018 Multi-University Training Contest 4 1005)

    6336.Problem E. Matrix from Arrays 不想解释了,直接官方题解: 队友写了博客,我是水的他的代码 ------>HDU 6336 子矩阵求和 至于为什么是4倍的, ...

  8. HDU 6315.Naive Operations-线段树(两棵树合并)(区间单点更新、区间最值、区间求和)+思维 (2018 Multi-University Training Contest 2 1007)

    6315.Naive Operations 题意很好理解,但是因为区间求和求的是向下取整的a[i]/b[i],所以直接分数更新区间是不对的,所以反过来直接当a[i]==b[i]的时候,线段树对应的位置 ...

  9. 2018.01.04 bzoj5291: [Bjoi2018]链上二次求和(线段树)

    传送门 线段树基础题. 题意:给出一个序列,要求支持区间加,查询序列中所有满足区间长度在[L,R][L,R][L,R]之间的区间的权值之和(区间的权值即区间内所有数的和). 想题555分钟,写题202 ...

随机推荐

  1. Alwayson--问题总结二

    1. 备份首选项作用 答:备份首选项并不影响实际的备份操作,只是在备份前提供标示当前副本是否是推荐的备份副本.管理员可以忽略备份首选项在任意副本上执行完整备份和日志备份. 2. 在辅助副本和主副本备份 ...

  2. Windows下常用的100个CMD指令以及常见的操作

    gpedit.msc—–组策略 2. sndrec32——-录音机 3. Nslookup——-IP地址侦测器 ,是一个 监测网络中 DNS 服务器是否能正确实现域名解析的命令行工具. 它在 Wind ...

  3. .NET MVC CSRF/XSRF 漏洞

    最近我跟一个漏洞还有一群阿三干起来了…… 背景: 我的客户是一个世界知名的药企,最近这个客户上台了一位阿三管理者,这个货上线第一个事儿就是要把现有的软件供应商重新洗牌一遍.由于我们的客户关系维护的非常 ...

  4. C#多线程编程系列(五)- 使用任务并行库

    目录 1.1 简介 1.2 创建任务 1.3 使用任务执行基本的操作 1.4 组合任务 1.5 将APM模式转换为任务 1.6 将EAP模式转换为任务 1.7 实现取消选项 1.8 处理任务中的异常 ...

  5. TCP BBR - 一键开启脚本

    这是秋水逸冰提供的TCP BBR一键开启脚本,脚本详细说明地址: https://teddysun.com/489.html 按照说明操作就可以了,注意问题:这个脚本获取有的时候可能有问题,如果提示脚 ...

  6. python 进程、线程、协程感悟

    进程: 感觉只是使用Process模块加以使用即可: # -*- coding: utf-8 -*- # data:2019-02-23 21:23 # user:DIY # file:thread_ ...

  7. 洛谷P3369 【模板】普通平衡树(Splay)

    题面 传送门 题解 鉴于最近的码力实在是弱到了一个境界--回来重新打一下Splay的板子--竟然整整调了一个上午-- //minamoto #include<bits/stdc++.h> ...

  8. 隐藏导航栏,偏移20PX

    1:让ViewController在NavigationBar下面开始布局. automaticallyAdjustsScrollViewInsets作用 当Controller上存在唯一一个UISc ...

  9. input 下拉框 的实践

    有一个需求  需要做一个input 框  点击出现列表 于是想到了  datalist控件 <input type="text" list="itemlist&qu ...

  10. linux下oracle数据库字符集修改

    linux下oracle数据库字符集修改 0.RHEL6.7.oracle11gr2 1.登录oracle.在安装oracle的用户下进入数据库. $ sqlplus / as sysdba 2.查询 ...