Colorful Tree

思路:

如果强制在线的化可以用树链剖分。

但这道题不强制在线,那么就可以将询问进行差分,最后dfs时再计算每个答案的修改值,

只要维护两个数组就可以了,分别表示根节点到当前节点某个颜色的个数和某个颜色长度和

代码:

  1. #pragma GCC optimize(2)
  2. #pragma GCC optimize(3)
  3. #pragma GCC optimize(4)
  4. #include<bits/stdc++.h>
  5. using namespace std;
  6. #define y1 y11
  7. #define fi first
  8. #define se second
  9. #define pi acos(-1.0)
  10. #define LL long long
  11. //#define mp make_pair
  12. #define pb emplace_back
  13. #define ls rt<<1, l, m
  14. #define rs rt<<1|1, m+1, r
  15. #define ULL unsigned LL
  16. #define pll pair<LL, LL>
  17. #define pli pair<LL, int>
  18. #define pii pair<int, int>
  19. #define piii pair<pii, int>
  20. #define pdd pair<double, double>
  21. #define mem(a, b) memset(a, b, sizeof(a))
  22. #define debug(x) cerr << #x << " = " << x << "\n";
  23. #define add(x) (x > MOD ? x-MOD :(x<0 ? x+MOD:x))
  24. #define fio ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
  25. //head 
  26.  
  27. const int N = 1e5 + ;
  28. vector<tuple<int, int, int>> g[N];
  29. vector<tuple<int, int, int, int>> vc[N];
  30. int n, m, a, b, c, d, x, y, u, v;
  31. int anc[N][], deep[N], len[N], ans[N];
  32. int cur_cnt[N], cur_sum[N];
  33. void dfs(int u, int o) {
  34. deep[u] = deep[o] + ;
  35. anc[u][] = o;
  36. for (int i = ; i < ; ++i) anc[u][i] = anc[anc[u][i-]][i-];
  37. for (auto t : g[u]) {
  38. int v = get<>(t), w = get<>(t);
  39. if(v != o) {
  40. len[v] = len[u] + w;
  41. dfs(v, u);
  42. }
  43. }
  44. }
  45. void DFS(int u, int o) {
  46. for (auto t : vc[u]) {
  47. int id = get<>(t), c = get<>(t), w = get<>(t), f = get<>(t);
  48. ans[id] -= f*cur_sum[c];
  49. ans[id] += f*cur_cnt[c]*w;
  50. }
  51. for (auto t : g[u]) {
  52. int v = get<>(t), c = get<>(t), w = get<>(t);
  53. if(v != o) {
  54. cur_cnt[c]++;
  55. cur_sum[c] += w;
  56. DFS(v, u);
  57. cur_cnt[c]--;
  58. cur_sum[c] -= w;
  59. }
  60. }
  61. }
  62. inline int lca(int u, int v) {
  63. if(deep[u] < deep[v]) swap(u, v);
  64. for (int i = ; i >= ; --i) if(deep[anc[u][i]] >= deep[v]) u = anc[u][i];
  65. if(u == v) return u;
  66. for (int i = ; i >= ; --i) if(anc[u][i] != anc[v][i]) u = anc[u][i], v = anc[v][i];
  67. return anc[u][];
  68. }
  69. int main() {
  70. scanf("%d %d", &n, &m);
  71. for (int i = ; i < n; ++i) scanf("%d %d %d %d", &a, &b, &c, &d), g[a].pb(b, c, d), g[b].pb(a, c, d);
  72. dfs(, );
  73. for (int i = ; i <= m; ++i) {
  74. scanf("%d %d %d %d", &x, &y, &u, &v);
  75. int a = lca(u, v);
  76. ans[i] = len[u]+len[v]-*len[a];
  77. vc[u].pb(i, x, y, );
  78. vc[v].pb(i, x, y, );
  79. vc[a].pb(i, x, y, -);
  80. }
  81. DFS(, );
  82. for (int i = ; i <= m; ++i) printf("%d\n", ans[i]);
  83. return ;
  84. }

AtCoder Beginner Contest 133 F Colorful Tree的更多相关文章

  1. AtCoder Beginner Contest 133 E - Virus Tree 2(组合数学)

    题意 n个点的树k种颜色,距离不超过2的点对需颜色不同,求方案数 Code(copy) #include<iostream> #include<cstdio> #include ...

  2. AtCoder Beginner Contest 137 F

    AtCoder Beginner Contest 137 F 数论鬼题(虽然不算特别数论) 希望你在浏览这篇题解前已经知道了费马小定理 利用用费马小定理构造函数\(g(x)=(x-i)^{P-1}\) ...

  3. AtCoder Beginner Contest 133

    目录 Contest Info Solutions A. T or T B.Good Distance C. Remainder Minimization 2019 D. Rain Flows int ...

  4. Atcoder Beginner Contest 070 D - Transit Tree Path

    题意:n个点,n-1条边,组成一个无向的联通图,然后给出q和k,q次询问,每次给出两个点,问这两个点之间的最短距离但必须经过k点. 思路:我当时是用优化的Dijkstra写的(当天刚学的),求出k点到 ...

  5. AtCoder Beginner Contest 171-175 F

    171 F - Strivore 直接把初始字符当成隔板,统计的方案数会有重复 为了避免重复情况,规定隔板字母尽可能最后出现,即在隔板字母后面不能插入含隔板字母的字符串 所以在隔板字母后插入的字符只有 ...

  6. AtCoder Beginner Contest 261 F // 树状数组

    题目链接:F - Sorting Color Balls (atcoder.jp) 题意: 有n个球,球有颜色和数字.对相邻的两球进行交换时,若颜色不同,需要花费1的代价.求将球排成数字不降的顺序,所 ...

  7. AtCoder Beginner Contest 260 F - Find 4-cycle

    题目传送门:F - Find 4-cycle (atcoder.jp) 题意: 给定一个无向图,其包含了S.T两个独立点集(即S.T内部间的任意两点之间不存在边),再给出图中的M条边(S中的点与T中的 ...

  8. AtCoder Beginner Contest 253 F - Operations on a Matrix // 树状数组

    题目传送门:F - Operations on a Matrix (atcoder.jp) 题意: 给一个N*M大小的零矩阵,以及Q次操作.操作1(l,r,x):对于 [l,r] 区间内的每列都加上x ...

  9. AtCoder Beginner Contest 249 F - Ignore Operations // 贪心 + 大根堆

    传送门:F - Keep Connect (atcoder.jp) 题意: 给定长度为N的操作(ti,yi). 给定初值为0的x,对其进行操作:当t为1时,将x替换为y:当t为2时,将x加上y. 最多 ...

随机推荐

  1. DSP6455的EMIFA口

    DSP6455的EMIFA口 声明:引用请注明出处http://blog.csdn.net/lg1259156776/ 支持两种不同的接口模式: 异步接口:标准的SRAM,ROM接口 同步接口:SBS ...

  2. Java程序的编写与执行、Java新手常见问题及解决方法|乐字节Java学习

    今天,我们来写一段Java程序.然后看看Java程序是如何执行的,以及Java新手小白遇到的问题和解决办法.   一.HelloWorld的编写 ① 新建一个XXX.java (文件的扩展名显示出来) ...

  3. 第一周-----Java 的核心优势和生态体系——程序员们希望他们编写的程序能够运行在不同的机器,不同的环境中,这需要一种体系中立的语言(即跨平台)。

    跨平台是Java 语言的核心优势,赶上最初互联网的发展,并随着互联网的发展而发展,建立了强大的生态体系,目前已覆盖IT各个行业的“第一大语言,称为IT界的英语”

  4. 轮播图CSS

    css3中的animation:动画名 持续时间 动画的速度曲线 动画开始之前的延迟 动画播放的次数 是否应该轮流反向播放动画 动画播放次数:n(定义应该播放多少次动画) : infinite(无限循 ...

  5. 自定义Hive函数

    7. 函数 7.1 系统内置函数 查看系统自带的函数:show functions; 显示自带的函数的用法:desc function upper(函数名); 详细显示自带的函数的用法:desc fu ...

  6. Mongodb: com.mongodb.MongoSocketReadException: Prematurely reached end of stream

    saveLocationInfo errorcom.mongodb.MongoSocketReadException: Prematurely reached end of stream at com ...

  7. [转帖]Nginx为什么高效?一文搞明白Nginx核心原理

    Nginx为什么高效?一文搞明白Nginx核心原理 咔咔侃技术 2019-09-06 15:37:00 https://www.toutiao.com/a6733057587622707724/ Ng ...

  8. [转帖]【JVM 知识体系框架总结】

    [JVM 知识体系框架总结] https://www.cnblogs.com/mousycoder/p/11612448.html JVM 内存分布 线程共享数据区:方法区->类信息,静态变量堆 ...

  9. gin mongodb restful api设计: 动态的patch接口

    目录 什么是Patch? Patch方法可以用来更新资源的一个组成部分 什么时候使用Patch? 当你仅需更新资源的某一项,即不完全也不幂等 那当我们的模型在数据库中几乎每个字段都可能会遇到改变的时候 ...

  10. Scratch2.0教材(9)——合体大变身

    教材说明 ——————— 1.本教材共96节课,适用于3-5年级.40人.40分钟的课堂: 2.初期我会把每节课的代码控制在10行以内,后期再逐渐增加: 3.欢迎提意见. 课程摘要 ——————— [ ...