【dfs序+线段树】P3178 [HAOI2015]树上操作

news2025/1/10 3:29:58

这道题,昨天调到一点多都没调出来,眼睛都要瞎了

今天看着题解边看边调出来了,但是还是感觉不是很会

m d,学的第一道关于树的DS就搞成这样

感觉很寄啊

P3178 [HAOI2015]树上操作 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

题意:

 

思路:

对于树上的修改操作,我们可以把树的dfs序搞出来,然后在dfs序上修改,这样就把维护树上信息变成维护序列信息了,维护序列的信息用线段树即可

注意,这里的dfs序是每个数仅出现2次,即进栈时记录一次,出栈时记录一次

进栈时记为1,出栈时记为-1

首先维护这么一个序列:

1 1 -1 1 1 -1 1 -1 -1 -1

还有维护dfs序:

1 4 4 2 3 3 5 5 2 1

我们线段树维护的就是这两个序列相乘:

1 4 -4 2 3 -3 5 -5 -2 -1

对于一棵子树,子树就相当于这个序列上的一段区间

操作1是对一个结点u +val,那就是对这个u的进栈的时间戳,即in[u]位置+val,对out[u]位置-val

操作2是对子树整体+val,那么就相当于对区间整体修改,区间中的数,如果是正的就+val,否则就是-val

即区间加:(区间中的所有1+区间中的所有-1)*val

操作3就是输出区间和即可

这些用线段树都非常好维护

 

 

Code:

#include <bits/stdc++.h>

#define int long long

using namespace std;

const int mxn=2e5+10;
const int mxe=2e5+10;

struct ty{
	int to,next;
}edge[mxe<<2];

struct ty2{
	int val,add;
}tree[mxe<<2];

int N,M,u,v,op,x,k,idx=0,tot=0;
int a[mxn],b[mxn],num[mxn];
int in[mxn],out[mxn],mp[mxn],head[mxn];

void dfs(int u,int fa){
	in[u]=++idx;
	mp[idx]=u;
	b[in[u]]=1;
	for(int i=head[u];~i;i=edge[i].next){
		if(edge[i].to==fa) continue;
		dfs(edge[i].to,u);
	}
	out[u]=++idx;
	mp[idx]=u;
	b[out[u]]=-1;
}
void pushup(int rt){
	tree[rt].val=tree[rt<<1].val+tree[rt<<1|1].val;
}
void build(int rt,int l,int r){
	if(l==r){
		tree[rt].val=b[l]*a[mp[l]];
		return;
	}
	int mid=l+r>>1;
	build(rt<<1,l,mid);
	build(rt<<1|1,mid+1,r);
	pushup(rt);
}
void pushdown(int rt,int l,int r){
	int mid=l+r>>1;
	tree[rt<<1].val+=tree[rt].add*(num[mid]-num[l-1]);
	tree[rt<<1|1].val+=tree[rt].add*(num[r]-num[mid]);
	tree[rt<<1].add+=tree[rt].add;
	tree[rt<<1|1].add+=tree[rt].add;
	tree[rt].add=0;
}
void change(int rt,int l,int r,int x,int k){
	tree[rt].val+=k;
	if(l==r) return;
	int mid=l+r>>1;
	if(x<=mid) change(rt<<1,l,mid,x,k);
	else change(rt<<1|1,mid+1,r,x,k);
}
void modify(int rt,int l,int r,int x,int y,int k){
	if(x<=l&&r<=y){
		tree[rt].add+=k;
		tree[rt].val+=(num[r]-num[l-1])*k;
		return;
	}
	if(tree[rt].add) pushdown(rt,l,r);
	int mid=l+r>>1;
	if(x<=mid) modify(rt<<1,l,mid,x,y,k);
	if(y>mid) modify(rt<<1|1,mid+1,r,x,y,k);
	pushup(rt);
}
int query(int rt,int l,int r,int x,int y){
	if(x<=l&&r<=y){
		return tree[rt].val;
	}
	if(tree[rt].add) pushdown(rt,l,r);
	int mid=l+r>>1;
	int res=0;
	if(x<=mid) res+=query(rt<<1,l,mid,x,y);
	if(y>mid) res+=query(rt<<1|1,mid+1,r,x,y);
	return res;
}
void add(int u,int v){
	edge[tot].to=v;
	edge[tot].next=head[u];
	head[u]=tot++;
}
void G_init(){
	tot=0;
	for(int i=0;i<=N;i++){
		head[i]=-1;
	}
}
void solve(){
	cin>>N>>M;
	G_init();
	for(int i=1;i<=N;i++) cin>>a[i];
	for(int i=1;i<=N-1;i++){
		cin>>u>>v;
		add(u,v);
		add(v,u);
	}
	dfs(1,-1);
	for(int i=1;i<=idx;i++) num[i]=num[i-1]+b[i];
	build(1,1,N+N);
	for(int i=1;i<=M;i++){
		cin>>op;
		if(op==1){
			cin>>x>>k;
			change(1,1,N+N,in[x],k);
			change(1,1,N+N,out[x],-k);
		}else if(op==2){
			cin>>x>>k;
			modify(1,1,N+N,in[x],out[x],k);
		}else{
			cin>>x;
			cout<<query(1,1,N+N,1,in[x])<<'\n';
		}
	}
}
signed main(){
	ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
	int __=1;//cin>>__;
	while(__--)solve();return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/558866.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

事务、分布式事务以及seata

事务 事务就是用户定义的一系列数据库操作&#xff0c;这些操作可以视为一个完成的逻辑处理工作单元&#xff0c;要么全部执行&#xff0c;要么全部不执行&#xff0c;是不可分割的工作单元。 事务的四个特效ACID Atomic 原子性&#xff0c;原子性是指事务必须是一个原子的操…

手摸手教你Vite+Vue3项目初始化及开源部署到GItee

项目初始化 本片文章主要记录项目的环境&#xff0c;项目搭建。 在开始本次学习中&#xff0c;鉴于你有前端三件套和vue的知识基础。 文档创建于2023年5月20日&#xff0c;大家都去过情人节了~我在肝代码&#xff01; 环境的搭建 node版本使用18.16.0。 目前&#xff08;202…

重磅!超星未来发布全新NOVA-ADCU智能驾驶参考方案

近日&#xff0c;超星未来重磅发布基于惊蛰R1芯片面向多场景打造的全新NOVA-ADCU智能驾驶参考方案&#xff0c;并亮相科技成果展。方案覆盖高阶行泊一体、轻量级行泊一体、双目智驾、路侧感知等场景&#xff0c;携手产业链上下游伙伴构建开放共赢的智能驾驶新生态。 以智能驾驶…

一种新的算法模型,填补微生物组纵向研究数据中的缺失值

谷禾健康 微生物组的纵向研究是一种长期跟踪微生物组变化的研究方法。在这类研究中&#xff0c;样本从同一人群或个人中多次采集&#xff0c;通过检测样本中微生物群落丰度的变化&#xff08;如不同菌群的比例和种类&#xff09;&#xff0c;来了解微生物组随时间的变化趋势和特…

【LeetCode225.用队列实现栈】你足够了解栈和队列吗?

​ 你好&#xff0c;欢迎来到我的博客&#xff01;作为一名程序员&#xff0c;我经常刷LeetCode题目来提升自己的编程能力。在我的博客里&#xff0c;我会分享一些我自己做过的题目和解题思路&#xff0c;希望能够帮助到大家。今天&#xff0c;我想和大家分享一道挑战性较高的题…

ApplicationRunner使用

本文来说下CommandLineRunner和ApplicationRunner的使用 文章目录 ApplicationRunner使用示例程序结果 CommandLineRunner使用示例程序结果 ApplicationListener触发时机使用实例程序结果注意问题 ApplicationRunner 使用起来很简单&#xff0c;只需要实现CommandLineRunner或者…

手机也可以搭建个人博客?安卓Termux+Hexo搭建属于你自己的博客网站【cpolar实现公网访问】

文章目录 1. 安装 Hexo2. 安装cpolar内网穿透3. 公网远程访问4. 固定公网地址 Hexo 是一个用 Nodejs 编写的快速、简洁且高效的博客框架。Hexo 使用 Markdown 解析文章&#xff0c;在几秒内&#xff0c;即可利用靓丽的主题生成静态网页。 下面介绍在Termux中安装个人hexo博客并…

领英Linkedin开发客户技巧分享

近期领英也是发布公告说2023年8月9号linkedin将关闭领英职场&#xff0c;我看很多有在用领英的小伙伴在问&#xff0c;这里回复一下&#xff0c;国内职场跟咱们做外贸使用linkedin国际版没啥太大关系&#xff0c;大可放心&#xff0c;要说影响的话肯定是有一些的&#xff0c;以…

数据库提权

数据库提权的前提就是得到数据库的账号密码。在webshell或本地进行提权。 数据库提权分为四步&#xff1a; 1.服务探针&#xff0c;探测出数据库的类型&#xff08;端口扫描等&#xff09; 2.信息搜集&#xff0c;就是获取到数据库的账号密码。权限要高。 读取数据库密码的…

SUSE系统修改静态IP

Suse系统使用yast管理配置&#xff0c;默认创建虚拟机&#xff0c;是使用DHCP获取动态IP的&#xff0c;这样非常不利于管理。因此&#xff0c;最好使用静态IP。 当前操作系统&#xff1a; eoisu01:~> uname -a Linux su01 6.3.2-1-default #1 SMP PREEMPT_DYNAMIC Mon May …

【服务器数据恢复】断电导致raid6磁盘扇区损坏的数据恢复案例

服务器数据恢复环境&#xff1a; 某品牌存储&#xff0c;12块SAS硬盘组建RAID6磁盘阵列&#xff0c;划分一个卷&#xff0c;分配给几台Vmware ESXI主机做共享存储。 卷中存放了大量的Windows虚拟机&#xff0c;虚拟机通过模板创建的&#xff0c;系统盘大小一致&#xff0c;数据…

苹果营收及增速分析,2022年营收达2055亿美元,增速为7%

众所周知&#xff0c;2007年1月&#xff0c;被乔布斯称为“苹果将彻底改变手机”的第一代iPhone正式发布&#xff0c;并于当年6月底上市销售。上市后&#xff0c;其受欢迎程度令人咋舌&#xff0c;销量一骑绝尘。短短5年内&#xff0c;其市场份额也由最初的3%升至18%&#xff0…

学术科研专用ChatGPT来了!

自从ChatGPT发布之后&#xff0c;各路大神都开始研究如何把它加入到自己的「科研工作流」当中。 比如「数学天才」陶哲轩就表示&#xff0c;他已经将ChatGPT纳入了自己的工作流程。 最近&#xff0c;一位网友也分享了自己的「ChatGPT 学术优化」项目。 没想到&#xff0c;在Gi…

六、数据仓库详细介绍(ETL)工具篇上

0x00 前言 在上篇&#xff0c;我们介绍过&#xff0c;ETL 的实现方式可以分为三种类型&#xff1a;完全依赖数据库、自研、第三方 ETL 工具。 我们需要根据实际情况去选择合适的方案。对于相对简单的 ETL 系统我们可以完全依赖数据库或者内部开发一个小型的的流程控制、调度工…

燕千云助力ITSM知识沉淀与复用

数字化时代IT服务知识沉淀痛点 随着企业数字化进程的推进&#xff0c;企业需要购入更多的智能化、数字化设备及软件&#xff0c;高效生产的同时&#xff0c;问题也层出不穷。而IT服务管理&#xff0c;可以为企业减少密集型的资源消耗&#xff0c;帮助企业以更高效、更流程化的…

28K入职字节的那天,我哭了····

先说一下自己的个人情况&#xff0c;计算机专业&#xff0c;18年本科毕业&#xff0c;一毕业就进入了“阿里”测试岗(进去才知道是接了个阿里外包项目&#xff0c;可是刚毕业谁知道什么外包不外包的)。 更悲催的是&#xff1a;刚入职因为家里出现一些变故&#xff0c;没有精力…

小电源,大讲究

高速先生成员--姜杰 成功的电源设计千篇一律&#xff0c;失败的直流压降各有各的秘密。 对于电源的直流压降&#xff0c;高速先生之前分享过一些低电压、大电流的电源案例&#xff0c;其实&#xff0c;对于种类繁多的小电源&#xff0c;由于电流相对较小&#xff0c;设计过程中…

玩了一下Midjourney很酷的设计工具

阿酷tony / 原创内容 / 2023-5-23 Midjourney是一款2022年3月面世的AI绘画工具&#xff0c;只要输入想到的文字&#xff0c;就能通过人工智能产出相对应的图片&#xff0c;耗时只有大约一分钟。 图 / Midjourney效果 图 / Midjourney效果 图 / Midjourney效果 图 / Midjourne…

基于copy命令的图片文本隐写(Misc出题)

这是一张普通的图片 我们使用010editor打开&#xff0c;很正常的jpg图片 这里顺便说一下&#xff0c;jpg图片会高亮&#xff0c;png则不会&#xff0c;下图则是一张png的图片 新建一个TXT文本&#xff0c;里面是我们想要给出的提示内容 在cmd里面切换到这些文件所在目录 copy命…

详细讲解u-boot之网络移植与调试

目录 一、前章回顾 二、硬件原理图检查 1.确认硬件原理图的fec对应的phy地址 2.修改网卡fec1的phy地址 3.网络初始化检查 4.fec部分管脚确认 5.检查是否存在多设备管脚复用 6.使用默认ENET2 三、编译烧写&#xff0c;下载验证 1.设置网络环境变量 2.使用软件配置&…