【bzoj4034】[HAOI2015]树上操作】的更多相关文章

http://www.lydsy.com/JudgeOnline/problem.php?id=4034 dfs序,树链剖分 #include<cstdio> #include<iostream> using namespace std; #define N 100001 typedef long long LL; int n,a[N]; ],to[N<<],tot; int fa[N],siz[N],dep[N]; int bl[N]; int id,L[N],R[N…
4034: [HAOI2015]树上操作 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 6163  Solved: 2025[Submit][Status][Discuss] Description 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个 操作,分为三种: 操作 1 :把某个节点 x 的点权增加 a . 操作 2 :把某个节点 x 为根的子树中所有点的点权都增加 a . 操作 3 :询问某个节点 x 到根的路径中所有…
4034: [HAOI2015]树上操作 题目:传送门 题解: 树剖裸题: 麻烦一点的就只有子树修改(其实一点也不),因为子树编号连续啊,直接改段(记录编号最小和最大) 开个long long 水模版 代码: #include<cstdio> #include<cstring> #include<cstdlib> #include<cmath> #include<algorithm> using namespace std; typedef lo…
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ4034 题意概括 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个 操作,分为三种: 操作 1 :把某个节点 x 的点权增加 a . 操作 2 :把某个节点 x 为根的子树中所有点的点权都增加 a . 操作 3 :询问某个节点 x 到根的路径中所有点的点权和. 题解 树链剖分. 然后对于子树修改,我们可以考虑dfs序. 树链剖分也是一种dfs序. 单点修改更简单,对于懒惰的我来…
这题把我写吐了...代码水平还是太弱鸡了啊... 这题就是先给你一些点,以及点权.然后给你一些向边构成一颗树,树的根节点是1. 然后给定三个操作 第一个是把指定节点的权值+W 第二个是把指定节点X为根(包括自己)的所有点权+W 第三个是求出指定节点到根节点的点权之和 嗯没错,听了大佬讲,肯定跑不了是DFS序,那么是用哪种呢???是N的还是2N的?? 我们思考一个问题,如果是N的,能表示什么遍历完成儿子节点的时间吗???显然不能 但是...2n的是可以的,因为节点DFS出现两次中间的节点都是他的儿…
题目描述 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个 操作,分为三种: 操作 1 :把某个节点 x 的点权增加 a . 操作 2 :把某个节点 x 为根的子树中所有点的点权都增加 a . 操作 3 :询问某个节点 x 到根的路径中所有点的点权和. 输入 第一行包含两个整数 N, M .表示点数和操作数.接下来一行 N 个整数,表示树中节点的初始权值.接下来 N-1  行每行三个正整数 fr, to , 表示该树中存在一条边 (fr, to) .再接下来 M 行,每行分别…
题目描述 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个操作,分为三种: 操作 1 :把某个节点 x 的点权增加 a . 操作 2 :把某个节点 x 为根的子树中所有点的点权都增加 a . 操作 3 :询问某个节点 x 到根的路径中所有点的点权和. 解法 还是非常典型的树链剖分. 操作\(1\):直接单点修改. 操作\(2\):区间修改,范围是\(idx[u]\)~\(idx[u]+sz[u]-1\). 操作\(3\):典型错误,直接求区间\(1~idx[u]\),我们每一…
Brief Description 您需要设计一种数据结构支持以下操作: 把某个节点 x 的点权增加 a . 把某个节点 x 为根的子树中所有点的点权都增加 a . 询问某个节点 x 到根的路径中所有点的点权和. Algorithm Design 我们考察操作对于查询的贡献. 对于操作1,如果节点y是节点x的后代,那么可以贡献\(a\) 对于操作2,如果节点y是节点x的后代,那么可以贡献\(a*(dep_y-dep_x+1)\) 我们可以使用两个树状数组来维护贡献. Code #include…
参考:https://www.cnblogs.com/liyinggang/p/5965981.html 题意:是一个数据结构题,树上的,用dfs序,变成线性的: 思路:对于每一个节点x,记录其DFS序,包括第一次到的序号,用in[x]记录,离开的序号out[x]记录, 再开一个数组seg,in:(序号——>节点的值):out:(序号——>节点的负值): 这样就可以使得 对于树来说:若所求的一个区间完全包含一个不相关子树,这个子树对结果不影响; 对于基于 线性 的线段树来说,同时包含in[x]…
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4034 树剖裸题: 一定要注意 long long !!! update 的时候别忘了 pushdown ... 代码如下: #include<iostream> #include<cstdio> #include<cstring> using namespace std; typedef long long ll; ; int n,m,tim,dfn[maxn],…