博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Codeforces 383C . Propagating tree【树阵,dfs】
阅读量:6168 次
发布时间:2019-06-21

本文共 1542 字,大约阅读时间需要 5 分钟。

标题效果:

有一棵树,有两种操作模式对本树:1:表示为(1 x val),在NOx加在节点上val,然后x每个节点加上儿子- val。给每个儿子一个儿子在一起-(- val),加到没有儿子为止。2:表示为(2 x)查询x节点上的值。

做法:

因为每次改动操作改动的并非一个值,而是非常多值。那我们将该题抽象成区间改动,点查询的问题。那怎么抽象呢?能够明确的是,每次操作尽管有加有减,可是
每次做加法操作。或者减法操作的都是同一部分数(也就是说,在某次加上同一个数的节点们。下次操作一定是加上或者减去同样的数),可是假设以树原来的编号为基础的话,那我们须要改动同样的数的那些节点肯定是不连续的,那就无法使用线段树或者树状数组的区间改动了。应该怎么办呢?我们考虑一下能不能将这树上的节点又一次排序,使得每次改动的值在一个连续的区间。

比方说有例如以下一棵树:

树的右边第一列代表深度,第二列代表着有着同样值(0或者1)的这些层的节点改动时都是同加或者同减的。比方第二层的节点和第四层的每一个节点在改动时进行的操作一定是全是加。或者全是减,不可能一部分节点加,一部分节点减的。

那我们怎么将每次操作须要改动的值都又一次编号为一个连续的区间呢? 如上图我们应该是又一次编号为这种:

1    2    3 4  5    6 7  8    9    10  //新数组下标 1  4    5    6    7    2    8    9    3    10  //又一次编号之后的数组

(第一行为新数组下标。第二行为新数组存的节点序号)

这样一来,我们就把每次须要改动的值变成了连续的了,比方说改动操作为(1 1 val),那么我们须要加val的节点在新数组中的区间为[1,5],须要减val的节点在[6,10];假设改动操作为(1 2 val)那么我们须要加val的节点在新数组中的区间为[6,8],须要减val的节点在[2,3]。
那详细怎么才干编号成这样呢?我们首先将每一个节点相应的上图右边第二列的值存在d[]数组中,先从根节点(1)開始。跳层DFS。以dfs的顺序将遍历到的儿子节点一个个的加到新数组中。

遍历完之后,再对根节点的每一个儿子做一遍同样的操作就可以。(详细能够看代码)

得到这个数组之后呢,我们还要预处理出对某个点进行改动操作,我们须要在那个区间加值。在哪个区间减值。也是用dfs,每一个节点的属性能够由儿子来确定。详细看代码和凝视:
代码:
#include 
#include
#include
#include
#define N 200020using namespace std;struct ee//存储须要改动哪些区间的结构体{ int x1,y1,x2,y2;}e[N];vector
g[N];int n,m,a[N],d[N],c[N],bef[N],index=1;void dfs1(int x,int fa,int deep)//处理d[]数组{ d[x]=deep; for(int i=0;i
=1) { c[i]+=a; i-=(i&(-i)); }}int main(){ scanf("%d%d",&n,&m); for(int i=1;i<=n;i++) scanf("%d",a+i); for(int i=0;i

版权声明:本文博客原创文章,博客,未经同意,不得转载。

本文转自mfrbuaa博客园博客,原文链接:http://www.cnblogs.com/mfrbuaa/p/4643283.html,如需转载请自行联系原作者

你可能感兴趣的文章
ajax的手写、封装和自定义设置
查看>>
class path resource [META-INF/xfire/services.xml] cannot be opened because it does not exist
查看>>
android自定义属性
查看>>
ERROR 1114 (HY000): The table 'table1' is full
查看>>
知乎网友神回复:哪怕是平时聊天吹牛的也没见程序员晒,这是为什么呢?
查看>>
Android实训案例(三)——实现时间轴效果的ListView,加入本地存储,实现恋爱日记的效果!...
查看>>
phalapi-进阶篇2(DI依赖注入和单例模式)
查看>>
MySQL 5.7.5 : GTID_EXECUTED系统表
查看>>
Hybrid框架UI重构之路:四、分而治之
查看>>
【原创】Valgrind 基础
查看>>
Es6系列之destructuring assignments
查看>>
CSS ID选择器与CLASS选择器
查看>>
mysql 索引B-Tree类型对索引使用的生效和失效情况详解
查看>>
指针的看法
查看>>
Cocos-2d 坐标系及其坐标转换
查看>>
LAMP网站的CACHE机制概要
查看>>
[MySQL 5.6] 5.6新参数slave_rows_search_algorithms
查看>>
ESXi5.1嵌套KVM虚拟化环境支持配置
查看>>
爬虫的小技巧之–如何寻找爬虫入口
查看>>
JVM学习(二)垃圾收集器
查看>>