[洛谷P3178][HAOI2015]树上操作

题目大意:有一棵点数为 $N$ 的树,以点 1 为根。然后有 $M$ 个操作。

1. 把 $x$ 的点权增加 $a$ 。

2. 把 $x$ 为根的子树中所有点的点权都增加 $a$ 。

3. 询问 $x$ 到根的路径中所有点的点权和。

题解:树链剖分模板题

卡点:我真的好久没打树剖了。。。

1.线段树$tag$写错

2.树剖$query$打错

3.一堆东西没开$long \; long$

 

C++ Code:

#include <cstdio>
#define maxn 100010
using namespace std;
int n, m, S[maxn], s[maxn];
int head[maxn], cnt;
struct Edge {int to, nxt;
} e[maxn << 1];
void add(int a, int b) {e[++cnt] = (Edge) {b, head[a]}; head[a] = cnt;
}
int dfn[maxn], son[maxn], sz[maxn], idx;
int dep[maxn], fa[maxn], top[maxn];
void dfs1(int rt) {sz[rt] = 1;for (int i = head[rt]; i; i = e[i].nxt) {int v = e[i].to;if (v != fa[rt]) {dep[v] = dep[rt] + 1;fa[v] = rt;dfs1(v);if (!son[rt] || sz[v] > sz[son[rt]]) son[rt] = v;sz[rt] += sz[v];}}
}
void dfs2(int rt) {dfn[rt] = ++idx;int v = son[rt];if (v) top[v] = top[rt], dfs2(v);for (int i = head[rt]; i; i = e[i].nxt) {v = e[i].to;if (v != fa[rt] && v != son[rt]) {top[v] = v;dfs2(v);}}
}
long long v[maxn << 2], cov[maxn << 2];
void build(int rt, int l, int r) {if (l == r) {v[rt] = s[l];return ;}int mid = l + r >> 1;build(rt << 1, l, mid);build(rt << 1 | 1, mid + 1, r);v[rt] = v[rt << 1] + v[rt << 1 | 1];
}
void pushdown(int rt, int len) {long long &tmp = cov[rt];v[rt << 1] += tmp * (len + 1 >> 1);v[rt << 1 | 1] += tmp * (len >> 1);cov[rt << 1] += tmp;cov[rt << 1 | 1] += tmp;tmp = 0;
}
void add(int rt, int l, int r, int L, int R, long long num) {if (L <= l && R >= r) {v[rt] += num * (r - l + 1);cov[rt] += num;return ;}int mid = l + r >> 1;if (cov[rt]) pushdown(rt, r - l + 1);if (L <= mid) add(rt << 1, l, mid, L, R, num);if (R > mid) add(rt << 1 | 1, mid + 1, r, L, R, num);v[rt] = v[rt << 1] + v[rt << 1 | 1];
}
long long ask(int rt, int l, int r, int L, int R) {if (L <= l && R >= r) {return v[rt];}int mid = l + r >> 1;long long ans = 0;
//	printf("%d %d %d %d %d\n", rt, l, r, L, R);if (cov[rt]) pushdown(rt, r - l + 1);if (L <= mid) ans = ask(rt << 1, l, mid, L, R);if (R > mid) ans += ask(rt << 1 | 1, mid + 1, r, L, R);return ans;
}
long long query(int rt) {long long ans = 0;while (top[rt] != 1) {ans += ask(1, 1, n, dfn[top[rt]], dfn[rt]);rt = fa[top[rt]];}ans += ask(1, 1, n, dfn[1], dfn[rt]);return ans;
}
int main() {scanf("%d%d", &n, &m);for (int i = 1; i <= n; i++) scanf("%d", &S[i]);for (int i = 1; i < n; i++) {int a, b;scanf("%d%d", &a, &b);add(a, b);add(b, a);}dep[top[1] = 1] = 1;dfs1(1);dfs2(1);for (int i = 1; i <= n; i++) s[dfn[i]] = S[i];build(1, 1, n);int op, a; long long x;while (m--) {scanf("%d%d", &op, &a);if (op == 3) {printf("%lld\n", query(a));} else {scanf("%lld", &x);if (op == 1) add(1, 1, n, dfn[a], dfn[a], x);else add(1, 1, n, dfn[a], dfn[a] + sz[a] - 1, x);}}return 0;
}

  

转载于:https://www.cnblogs.com/Memory-of-winter/p/9459829.html

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

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

相关文章

实现 通过数据库里一个字段值相等 则把 他合为一条数据

需求&#xff1a; 把红色合为一条数据&#xff0c;绿色合为一条数据 结果&#xff1a; 不多说直接上代码......................................................... // 先查所有数据 const goods await service.goods.findAllGoodsWithParams({where: params,offset: ctx.p…

CSS定义字体间距 字体行与行间距

1 2     letter-spacing:像素&#xff08;字母或中文字的左右间距&#xff09;3 4 word-spacing:像素&#xff08;两个单词之间的左右间距&#xff09;5 6 line-height:像素&#xff08;两行之间的间距&#xff09;7 8 text-decoration:字体的装饰&am…

float与double类型参数区别_8大基本数据类型及包装类,不知道这些点别说自己是大佬...

一般地&#xff0c;当需要使用数字的时候&#xff0c;我们通常使用内置数据类型&#xff0c;如&#xff1a;byte、int、long、double 等。然而&#xff0c;在实际开发过程中&#xff0c;我们经常会遇到需要使用对象&#xff0c;而不是内置数据类型的情形。为了解决这个问题&…

宣布EAXY:在Java中简化XML

Java中的XML库是一个雷区。 操作和读取XML所需的代码量令人震惊&#xff0c;使用不同的库遇到类路径问题的风险很大&#xff0c;并且命名空间的处理带来了很多混乱和错误。 最糟糕的是&#xff0c;情况似乎并没有改善。 一位同事让我意识到JOOX库。 这是解决这些问题的一个很好…

9-客户端集成IdentityServer

1-创建客户端的webapi项目 E:\coding\netcore\IdentityServerSample>dotnet new webapi --name IdentityCredentialApi 2-在需要启用授权的方法上增加Authorize标签 3-使用nuget工具安装 IdentityServer4.AccessTokenValidation 4-启用客户端授权&#xff0c; 需要配置连接…

js parseInt()与Number()区别

说到转换成数字类型&#xff0c;我首先想到的是parseInt&#xff08;&#xff09;方法&#xff0c;后来接触多了才发现还有一个Number()方法&#xff0c;同样是转换成数字类型&#xff0c;这两种方法有什么不同的呢&#xff1f; 1.parseInt&#xff08;&#xff09;&#xff1a…

java大小端字节流解析_玩转socket之字节流操作--拼包、拆包

玩转socket之字节流操作--拼包、拆包我们开发中用得最多的HTTP协议及超文本传输协议&#xff0c;是一种基于TCP/IP的文本传输协议。基本很少碰到字节流操作。但是我过我们要用socket&#xff0c;实现一套基本TCP/IP协议的自定义协议&#xff0c;那么&#xff0c;对于字节流的操…

js替换数组中字符串实例

这个是替换数组中的一个对象字符串&#xff1b; 直接上代码&#xff1a; 1 var aaa[ 2 {"name":"张珊","sex":"man"}, 3 {"name":"李斯","sex":"woman"}, 4 …

ie浏览器升级_微软呼吁用户停用IE浏览器 2020年将不再更新升级

驱动中国2019年2月10日消息 IE浏览器作为美国微软公司推出的一款网页浏览器成为许多人接触互联网初选&#xff0c;深受不少用户喜欢但这款流畅多年的浏览器正式遭弃用&#xff01;今日微软网络安全专家在在官方Winhows IT Pro上发帖呼吁用户停止使用IE浏览器&#xff01;微软网…

有条件忽略测试的JUnit规则

我一直认为使用Ignore停用测试是一个坏主意。 例外&#xff0c;这可能是一种将间歇性失败的测试放入隔离区以供以后处理的方法&#xff08;如Martin Fowler 在此处所述 &#xff09;。 随着越来越多的测试不断被忽略和遗忘&#xff0c;这带来了测试套件衰减的危险。 因此&#…

【学亮IT手记】PL/SQL游标编程

游标提供了一种从表中检索数据并进行操作的灵活手段&#xff0c;主要用在服务器上&#xff0c;处理由客户端发送给服务器端的sql语句&#xff0c;或者是批处理、存储过程、触发器中的数据处理请求。 显式游标 是由用户声明和操作的一种游标&#xff0c;通常用于将查询出的结果集…

CentOS安装zookeeper

第一步&#xff0c;先去Apache下载安装包 http://mirror.bit.edu.cn/apache/zookeeper/ 第二步&#xff0c;上传到服务器并解压 tar -zxvf zookeeper-3.4.6 第三步&#xff0c;新建一个文件夹 #先改个名 mv zookeeper-3.4.6 zookeeper cd zookeeper mkdir data 第四步&#xff…

php根据id查找条件怎么写_thinkphp where()条件查询

今天来给大家讲下查询最常用但也是最复杂的where方法&#xff0c;where方法也属于模型类的连贯操作方法之一&#xff0c;主要用于查询和操作条件的设置。where方法的用法是ThinkPHP查询语言的精髓&#xff0c;也是ThinkPHP ORM的重要组成部分和亮点所在&#xff0c;可以完成包括…

3分钟简单了解 prototype 和 __proto__

关于prototype 1. 所有的函数都会有一个prototype属性&#xff0c;属性值是一个普通对象&#xff1b; 2. 当我们去new一个构造函数的实例时&#xff0c;构造函数的原型对象(prototype)会被赋值给它实例的[[Prototype]]属性上&#xff1b; 3. prototype可被称为“显式原型”。…

rdlc报表 矩形高固定_固定资产条码管理系统特点分析

固定资产条码管理系统的特点都有什么&#xff1f;固定资产是维持企业稳定健康发展的重要物质保障&#xff0c;若想最大化发挥固定资产的效能作用&#xff0c;满足生产经营管理的需求&#xff0c;提高应对企业内外部经营环境变化的能力&#xff0c;企业管理者就必须及时了解固定…

Spring 4中@ControllerAdvice的改进

在Spring 4的许多新功能中&#xff0c;我发现了ControllerAdvice的改进。 ControllerAdvice是Component的特殊化&#xff0c;用于定义适用于所有RequestMapping方法的 ExceptionHandler&#xff0c; InitBinder和ModelAttribute方法。 在Spring 4之前&#xff0c; ControllerAd…

bzoj 2007 [Noi2010]海拔——最小割转最短路

题目&#xff1a;https://www.lydsy.com/JudgeOnline/problem.php?id2007 一个点的高度一定不是0就是1。答案一定形如一个左上角的连通块全是0的点、一个右下角的连通块全是1的点。 注意从东到西还有从南到北的边也有用&#xff01;因为不一定是一个阶梯形的&#xff0c;还可以…

php 四维数组_PHP 多维数组

PHP - 两维数组两维数组是数组的数组(三维数组是数组的数组的数组)。首先&#xff0c;让我们看看下面的表格&#xff1a;品牌库存销量Volvo3320BMW1715Saab52Land Rover1511我们能够在两维数组中存储上表中的数据&#xff0c;就像这样&#xff1a;$cars array(array("Vol…

Vue于React特性对比(二)

一&#xff0c;关于响应式数据更新方式的实现 1&#xff09;只有在data里面定义的数据才会有响应式更新 vue依赖的defineProperty的数据劫持加上依赖数据&#xff0c;实现数据的响应式更新。可以称之为依赖式的响应。因为依赖所以注定了只会更新与data相关的数据。 2&#xff0…

《黑客攻防技术宝典Web实战篇@第2版》读书笔记1:了解Web应用程序

读书笔记第一部分对应原书的第一章&#xff0c;主要介绍了Web应用程序的发展&#xff0c;功能&#xff0c;安全状况。 Web应用程序的发展历程 早期的万维网仅由Web站点构成&#xff0c;只是包含静态文档的信息库&#xff0c;随后人们发明了Web浏览器用来检索和显示那些文档&am…