CF2006B Iris and the Tree

news/2024/9/23 0:10:02

题目链接

题解

知识点:DFS序。

编号已经满足 dfs 序,因此对于边 \(t_v = (u,v), u < v\) ,有且仅有两条路径 \(v - 1 \to v, R_v \to R_v \bmod n + 1\) 会经过这条边,前者是进入子树 \(v\) 时经过,后者是离开子树 \(v\) 时经过。其中 \(R_v\) 表示子树 \(v\) 内的最大编号,我们可以用 dfs 预处理。

显然,当一条路径存在未确定的边时,它的距离等于路径上确定的边的边权和加上剩余未分配的权值(全给未确定的边即可)。

设总和为 \(ans\) ,最初 \(n\) 条路径的距离都是 \(0 +w\) ,因此 \(ans = nw\)

每次确定一个边权 \(y\),未分配的权值将会减少 \(y\),因此所有不经过这条边且存在未确定边的路径的距离都将减少 \(y\),而经过这条边的路径的距离不会发生变化。设剩余存在未确定边的路径数为 \(rest\) ,那么一次操作后答案将更新为 \(ans - (rest - 2)y\)

此外,一次操作后,如果存在路径已经完全确定时,它们的距离就不能加上未分配的权值,假设 \(w'\) 是当前未分配的权值,那么需要将答案更新为 \(ans - w\)

最后,我们可以预处理每条路径未确定边的个数 \(cnt\) ,每次确定一条边,会更新经过它的两条路径的 \(cnt\) 值。当某条路径的 \(cnt\) 归零,表示它已经完全确定。

时间复杂度 \(O(n)\)

空间复杂度 \(O(n)\)

代码

#include <bits/stdc++.h>
using namespace std;
using ll = long long;vector<int> g[200007];
int cnt[200007];int R[200007];
void dfs(int u) {R[u] = u;for (auto v : g[u]) {dfs(v);R[u] = max(R[u], R[v]);}
}bool solve() {int n;ll w;cin >> n >> w;for (int i = 1;i <= n;i++) {cnt[i] = 0;g[i].clear();}for (int i = 2;i <= n;i++) {int p;cin >> p;g[p].push_back(i);}dfs(1);for (int i = 2;i <= n;i++) {cnt[i - 1]++;cnt[R[i]]++;}int rest = n;ll ans = n * w;for (int i = 1;i <= n - 1;i++) {int x;ll y;cin >> x >> y;cnt[x - 1]--;cnt[R[x]]--;w -= y;ans -= 1LL * (rest - 2) * y;if (cnt[x - 1] == 0) ans -= w, rest--;if (cnt[R[x]] == 0) ans -= w, rest--;cout << ans << ' ';}cout << '\n';return true;
}int main() {std::ios::sync_with_stdio(0), std::cin.tie(0), std::cout.tie(0);int t = 1;cin >> t;while (t--) {if (!solve()) cout << -1 << '\n';}return 0;
}

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

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

相关文章

学习高校课程-软件工程-敏捷开发(ch5)

WHAT IS AGILITY 什么是敏捷性 An agile team is a nimble team able to appropriately respond to changes. Change is what software development is very much about. Changes in the software being built, changes to the team members, changes because of new technolog…

从零开始一个git操作实例,图文并茂

徒弟不懂git怎么用, 于是写了篇文章, 把本地git操作从头写了一遍, 自己去看吧!0、基本概念 •Git是一个免费、开源的、分布式版本控制系统 •它使用一个特殊的叫做仓库的数据库来记录文件的变化 •仓库中的每个文件都有一个完整的版本历史记录 1)安装 sudo apt-update sud…

Java反序列化利用链篇 | JdbcRowSetImpl利用链分析

JdbcRowSetImpl利用链 前言 首先说明一下:利用链都有自己的使用场景,要根据场景进行选择不同的利用链。 JdbcRowSetImpl利用链用于fastjson反序列化漏洞中。 为什么? 因为fastjson会在反序列化类时自动调用set开头的方法(不一定是setter方法),而JdbcRowSetImpl中存在一个…

torch.stack

看一下stack的直观解释,动词可以简单理解为:把……放成一堆、把……放成一摞。 torch.stack方法用于沿着一个新的维度 join(也可称为cat)一系列的张量(可以是2个张量或者是更多),它会插入一个新的维度,并让张量按照这个新的维度进行张量的cat操作。值得注意的是:张量序…

Java反序列化调用链分析系列 | URLDNS链

URLDNS链 URLDNS链是java通过反序列化发起dns请求的利用链。一般用于测试反序列化漏洞。 该链比较简单,利用链也比较短。 其中入口类为 HashMap,执行类为URLStreamHandler的hashCode()方法。 整个调用链如下: HashMap.readObject() HashMap.putVal() HashMap.hash()URL.hash…

控制请求并发数量:p-limit 源码解读

p-limit 是一个控制请求并发数量的库,他的整体代码不多,思路挺好的,很有学习价值; 举例 当我们同时发起多个请求时,一般是这样做的 Promise.all([requestFn1,requestFn2,requestFn3 ]).then(res =>{})或者 requestFn1() requestFn2() requestFn3()而使用 p-limit 限制并…

程序员职业发展之路思考:工程师的等级阶梯

德雷福斯模型:新手到专家 德雷福斯模型(Dreyfus model)是在 1980 年,Dreyfus 兄弟共同提出的技能习得模型。 它是一个技能习得的阶梯模型,也可以用来考察行业技术能手的分级。该模型由上而下分成:专家、精通者、胜任者、高级新手、新手五个等级,越到上面人数占比越少。新…

2024 人工智能学习内容

第六组思维导图:图形的认识