Description

Input

Output

Sample Input

4 3 5
1 9 2
7 6 5 1
2 3
3 1
3 4
1 2 3 2
1 1 2
1 4 2
0 2 1
1 1 2
1 4 2

Sample Output

84
131
27
84

HINT

Solution

一个讲解

还是改成括号序的写法吧……感觉好理解还好码……

一开始插入和删除函数是像下面这样分开写的,$vis$函数加加减减不知道哪里错了……如果有大爷看出来哪里错了和我说一声啊QAQ

  1. void Ins(int x)
  2. {
  3. vis[x]++;
  4. if (vis[x]==) Delicacy-=v[c[x]]*w[Keg[c[x]]], Keg[c[x]]--;
  5. else Keg[c[x]]++, Delicacy+=v[c[x]]*w[Keg[c[x]]];
  6. }
  7.  
  8. void Del(int x)
  9. {
  10. vis[x]--;
  11. if (vis[x]==) Keg[c[x]]++, Delicacy+=v[c[x]]*w[Keg[c[x]]];
  12. else Delicacy-=v[c[x]]*w[Keg[c[x]]], Keg[c[x]]--;
  13. }
  14.  
  15. void Recov(int x,int val)
  16. {
  17. if (vis[x]==) Del(x), c[x]=val, Ins(x);
  18. c[x]=val;
  19. }

后来改成天下第一的写法对$vis$搞异或就过了……至今不知道为什么……

还有我才发现我二轮的树上莫队写的是对的啊……只不过$cmp$函数写错真的太开心了……

虽然多那30分也无济于事就是了……

话说我二轮的树上莫队既然是对的那我2月份写的那一发树分块糖果公园为什么T成狗啊

Code

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cmath>
  4. #include<algorithm>
  5. #define N (200009)
  6. #define LL long long
  7. using namespace std;
  8.  
  9. struct Que{int l,r,t,num,flag; LL ans;}Q[N];
  10. struct Mdf{int pre,nxt,pos;}M[N];
  11. struct Edge{int to,next;}edge[N<<];
  12. LL Delicacy,v[N],w[N];
  13. int n,m,q,x,y,opt,l=,r,flag,Q_num,M_num,Time,dfs_num;
  14. int Keg[N*],vis[N],ID[N],a[N];
  15. int Fir[N],Sec[N],f[N][],Depth[N],c[N];
  16. int head[N],num_edge;
  17. bool cmp1(Que a,Que b)
  18. {
  19. if (ID[a.l]==ID[b.l])
  20. return ID[a.r]==ID[b.r]?a.t<b.t:ID[a.r]<ID[b.r];
  21. else return ID[a.l]<ID[b.l];
  22. }
  23. bool cmp2(Que a,Que b) {return a.num<b.num;}
  24.  
  25. void add(int u,int v)
  26. {
  27. edge[++num_edge].to=v;
  28. edge[num_edge].next=head[u];
  29. head[u]=num_edge;
  30. }
  31.  
  32. void Ins(int x)
  33. {
  34. if (vis[x]) Delicacy-=v[c[x]]*w[Keg[c[x]]], Keg[c[x]]--;
  35. else Keg[c[x]]++, Delicacy+=v[c[x]]*w[Keg[c[x]]];
  36. vis[x]^=;
  37. }
  38.  
  39. void Recov(int x,int val)
  40. {
  41. if (vis[x]) Ins(x),c[x]=val,Ins(x);
  42. else c[x]=val;
  43. }
  44.  
  45. void MoQueue(int num)
  46. {
  47. while (Time<Q[num].t) Recov(M[Time+].pos,M[Time+].nxt), Time++;
  48. while (Time>Q[num].t) Recov(M[Time].pos,M[Time].pre), Time--;
  49. while (l<Q[num].l) Ins(a[l++]);
  50. while (l>Q[num].l) Ins(a[--l]);
  51. while (r<Q[num].r) Ins(a[++r]);
  52. while (r>Q[num].r) Ins(a[r--]);
  53. Q[num].ans=Delicacy;
  54. if (Q[num].flag)
  55. {
  56. Ins(Q[num].flag);
  57. Q[num].ans=Delicacy;
  58. Ins(Q[num].flag);
  59. }
  60. }
  61.  
  62. void DFS(int x,int fa)
  63. {
  64. f[x][]=fa;
  65. for (int i=; i<=; ++i) f[x][i]=f[f[x][i-]][i-];
  66. Depth[x]=Depth[fa]+; Fir[x]=++dfs_num;
  67. a[dfs_num]=x;
  68. for (int i=head[x]; i; i=edge[i].next)
  69. if (edge[i].to!=fa) DFS(edge[i].to,x);
  70. Sec[x]=++dfs_num; a[dfs_num]=x;
  71. }
  72.  
  73. int LCA(int x,int y)
  74. {
  75. if (Depth[x]<Depth[y]) swap(x,y);
  76. for (int i=; i>=; --i)
  77. if (Depth[f[x][i]]>=Depth[y]) x=f[x][i];
  78. if (x==y) return x;
  79. for (int i=; i>=; --i)
  80. if (f[x][i]!=f[y][i]) x=f[x][i], y=f[y][i];
  81. return f[x][];
  82. }
  83. int main()
  84. {
  85. scanf("%d%d%d",&n,&m,&q);
  86. int unit=pow(n,2.0/3.0);
  87. for (int i=; i<=(n*); ++i) ID[i]=(i-)/unit+;
  88. for (int i=; i<=m; ++i) scanf("%lld",&v[i]);
  89. for (int i=; i<=n; ++i) scanf("%lld",&w[i]);
  90. for (int i=; i<=n-; ++i)
  91. scanf("%d%d",&x,&y), add(x,y), add(y,x);
  92. for (int i=; i<=n; ++i) scanf("%d",&c[i]);
  93. DFS(,);
  94. for (int i=; i<=q; ++i)
  95. {
  96. scanf("%d%d%d",&opt,&x,&y);
  97. if (opt==)
  98. {
  99. if (Fir[x]>Fir[y]) swap(x,y);
  100. int lca=LCA(x,y);
  101. if (lca==x) x=Fir[x], y=Fir[y], flag=;
  102. else x=Sec[x], y=Fir[y], flag=lca;
  103. Q[++Q_num]=(Que){x,y,M_num,i,flag,};
  104. }
  105. else M[++M_num]=(Mdf){c[x],y,x}, c[x]=y;
  106. }
  107. for (int i=M_num; i>=; --i)
  108. c[M[i].pos]=M[i].pre;
  109. sort(Q+,Q+Q_num+,cmp1);
  110. for (int i=; i<=Q_num; ++i)
  111. MoQueue(i);
  112. sort(Q+,Q+Q_num+,cmp2);
  113. for (int i=; i<=Q_num; ++i)
  114. printf("%lld\n",Q[i].ans);
  115. }

BZOJ3052:[WC2013]糖果公园(树上莫队)的更多相关文章

  1. P4074 [WC2013]糖果公园 树上莫队带修改

    题目链接 Candyland 有一座糖果公园,公园里不仅有美丽的风景.好玩的游乐项目,还有许多免费糖果的发放点,这引来了许多贪吃的小朋友来糖果公园游玩. 糖果公园的结构十分奇特,它由 nn 个游览点构 ...

  2. BZOJ.3052.[WC2013]糖果公园(树上莫队 带修改莫队)

    题目链接 BZOJ 当然哪都能交(都比在BZOJ交好),比如UOJ #58 //67376kb 27280ms //树上莫队+带修改莫队 模板题 #include <cmath> #inc ...

  3. BZOJ 3052: [wc2013]糖果公园 | 树上莫队

    题目: UOJ也能评测 题解 请看代码 #include<cstdio> #include<algorithm> #include<cstring> #includ ...

  4. 【WC2013】 糖果公园 - 树上莫队

    问题描述 Candyland 有一座糖果公园,公园里不仅有美丽的风景.好玩的游乐项目,还有许多免费糖果的发放点,这引来了许多贪吃的小朋友来糖果公园游玩.糖果公园的结构十分奇特,它由 n 个游览点构成, ...

  5. 【WC2013】糖果公园 [树上莫队]

    题意: 一棵树,修改一个点的颜色,询问两点路径上每种颜色的权值$val[c]$*出现次数的权值$cou[w[c]]$的和 sro VFK 树上莫队 按照王室联邦的方法分块,块的大小直径个数有保证,并不 ...

  6. 洛谷P4074 [WC2013]糖果公园(莫队)

    传送门 总算会树形莫队了…… 上次听说树形莫队是给树分块,实在看不懂.然后用括号序列的方法做总算能弄明白了 先说一下什么是括号序列,就是在$dfs$的时候,进入的时候记录一下,出去的时候也记录一下 拿 ...

  7. BZOJ3052 [wc2013] 糖果公园 【树上莫队】

    树上莫队和普通的序列莫队很像,我们把树进行dfs,然后存一个长度为2n的括号序列,就是一个点进去当作左括号,出来当作右括号,然后如果访问从u到v路径,我们可以转化成括号序列的区间,记录x进去的时候编号 ...

  8. 【BZOJ-3052】糖果公园 树上带修莫队算法

    3052: [wc2013]糖果公园 Time Limit: 200 Sec  Memory Limit: 512 MBSubmit: 883  Solved: 419[Submit][Status] ...

  9. LUOGU P4074 [WC2013]糖果公园 (树上带修莫队)

    传送门 解题思路 树上带修莫队,搞了两天..终于开O2+卡常大法贴边过了...bzoj上跑了183s..其实就是把树上莫队和带修莫队结合到一起,首先求出括号序,就是进一次出一次那种的,然后如果求两个点 ...

随机推荐

  1. 对象的深度拓展$.extend(true,{},a,b),深入理解,小心陷阱

    转载:https://www.cnblogs.com/DJeanWeb/p/4388689.html $.extend一般情景下,使用深度拓展两个对象时,我们想要的效果是,b对象覆盖掉a对象中存在的所 ...

  2. 【原】Docker入门之Centos7.0+安装

    服务器配置:1核2G 40G 硬盘,Centos 7.4. 以下全程是在 root 用户下操作: 1.卸载旧版本 yum remove docker \ docker-client \ docker- ...

  3. POJ 1284 Primitive Roots 数论原根。

    Primitive Roots Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 2479   Accepted: 1385 D ...

  4. maven(视频学习)

    一.maven的介绍 二.maven的环境搭建 三.maven的结构 四.maven常用的构建命令 五.maven自动创建目录骨架 六.maven中的坐标和仓库 七.在eclipse中安装maven插 ...

  5. Javascript中的bind详解

    前言 用过React的同学都知道,经常会使用bind来绑定this. import React, { Component } from 'react'; class TodoItem extends ...

  6. Python手写模拟单向链表对象,栈对象和树

    单向链表: class error(Exception): def __init__(self,msg): super(error,self).__init__() self.msg=msg def ...

  7. windows 查看端口

    windowsnetstat命令查看进程:netstat -ano查看占用端口进程:netstat -ano|findstr “端口号”,例子netstat -ano|findstr “8080”.t ...

  8. div实现返回符,倒三角,椭圆+小知识收集

    收集: 1,返回符(伪类元素): .back:before {content: "";width: .3rem;height: .3rem;border-left: .04rem ...

  9. 移动端地区选择mobile-select-area插件的使用方法

    顾名思义,mobile-select-area插件就是使用在移动端上的进行地区选择的插件,而且使用方法简单,我就说我是怎么用的吧 一.准备工作 首先肯定要下载插件对应的css+js文件, 当你下载好这 ...

  10. android--Git上克隆项目遇到的坑

    直接上图,首先你得有你得GitHub项目地址,如下: 然后打开android studio,选择新建项目时从Git上克隆: 点击clone等待完成,新窗口打开. 打开之后可能.或许.大概.也许会出现下 ...