CF1120D Power Tree
题意简述
给你一棵有根树,定义叶子为度数为1的点。
你可以以$ w_x \(的代价控制\)x\(点。选择控制之后可以给它的子树里的叶子加
上\)t (t \in Z )$。
你要以最小的总代价使得:另一个人在叶子上任意放数,你都可以把它
们都变成0。
最后输出最小的总代价,以及有多少点可能被控制,以及每个可能被控制的点的编号
思路索引
首先,我们可以把所有的叶子节点按照 dfs序 抽象成一个序列
接下来,我们可以很神奇的发现,每一个点就对应着一个区间这不是废话吗
然后,选择某个区间后,我们就可以对它进行区间加的操作
既然是区间操作,肯定是不方便的,然后就很自然的想到了差分哪里自然了
若点\(x\)对应区间\([l,r]\),那么,我们控制点x,就等同于在\(l\)处\(+t\),在\(r+1\)处\(-t\)(因此,我们需要虚构出一个新的叶子节点,以保证不会爆掉)
我们观察一下这个序列,发现如果原数组均为0,则差分数组也均为0
所以说,我们可以在\(l\)到\(r+1\)之间连一条边权为\(w_x\)的边,我们可以在这条边的一端加上一个数,而在另一端减去一个相同的数
我们发现,若所有叶子都联通,那么因为差分数组的和为0,所以我们必然能将每一个点都变成0
求一遍最小生成树即可
代码实现
//```
#include<bits/stdc++.h>
#define ll long long
#define now edge[i].v
#define rep(i,l,r) for(int i=l;i<=r;i++)
using namespace std;
const int SZ=2e5+7;
ll ans;
int cnt;
int L,R;
int u,v;
int n,T;
int w[SZ];
int fa[SZ];
int sz[SZ];
bool vis[SZ];
int head[SZ];
bool f[SZ];
int l[SZ],r[SZ];
struct wxp{
int v,nxt;
}edge[SZ<<1];
struct pb{
int u,v,w,o;
}E[SZ];
bool cmp(pb p1,pb p2){
return p1.w<p2.w;
}
int getfa(int x){
return fa[x]==x?x:fa[x]=getfa(fa[x]);
}
void add(int u,int v){
edge[++cnt]=(wxp){v,head[u]};
head[u]=cnt;
}
void dfs(int x){
sz[x]=1;
vis[x]=1;
for(int i=head[x];i;i=edge[i].nxt)
if(!vis[now]){
dfs(now);
sz[x]+=sz[now];
l[x]=min(l[x],l[now]);
r[x]=max(r[x],r[now]);
}
if(sz[x]==1) l[x]=r[x]=++T;
E[x]=(pb){l[x],r[x]+1,w[x],x};
}
int main(){
scanf("%d",&n);
rep(i,1,n) scanf("%d",&w[i]);
rep(i,1,n-1){
scanf("%d%d",&u,&v);
add(u,v),add(v,u);
}
memset(l,0x3f,sizeof(l));
dfs(1);
sort(E+1,E+n+1,cmp);
rep(i,1,T+1) fa[i]=i;
int sum=0;
for(L=1;L<=n;L=R+1){
R=L;
while(E[R+1].w==E[L].w&&R<n) R++;
rep(i,L,R){
u=E[i].u,v=E[i].v;
if(getfa(u)!=getfa(v)) f[E[i].o]=1,sum++;
}
rep(i,L,R){
u=E[i].u,v=E[i].v;
if(getfa(u)!=getfa(v)){
ans+=1ll*E[i].w;
fa[fa[u]]=fa[v];
}
}
}
printf("%I64d %d\n",ans,sum);
rep(i,1,n) if(f[i]) printf("%d ",i);
}
CF1120D Power Tree的更多相关文章
- CF1120D Power Tree(构造题,差分,最小生成树)
很有趣的一道题. 首先可以对每个叶子进行编号.按照DFS到的顺序即可.(假设从 $1$ 到 $k$) 然后对每个点求出它管辖的所有叶子的编号.因为是DFS序所以这一定是个区间.设点 $u$ 的这个区间 ...
- Codeforces 1120D Power Tree [最小生成树]
洛谷 Codeforces 这题怎么一个中文题解都没有,是不是你们都认为太水了-- 思路 显然可以用dfs序把每个节点变成给一个区间的叶子节点加上某个数. 显然把叶子序列差分一下变为\(a_1,a_2 ...
- [CF607D]Power Tree
题目大意: 一棵树初始只有一个编号为$1$的权值为$w_1$的根.$q(q\le2\times10^5)$次操作,每次可以给出$v,w(w<10^9)$,新建一个结点作为$v$的子结点,权值为$ ...
- Solution -「树上杂题?」专练
主要是记录思路,不要被刚开始错误方向带偏了 www 「CF1110F」Nearest Leaf 特殊性质:先序遍历即为 \(1 \to n\),可得出:叶子节点编号递增或可在不改变树形态的基础上调整为 ...
- cf Round 607
A.Chain Reaction(DP+二分) 题意:一排有n个灯塔,每个灯塔给出坐标xi和力量yi,每次从最右边依次点亮灯塔,每点亮一个灯塔,它左边的距离它yi范围内的灯塔将受到损坏.现在允许在最右 ...
- codeforces选做
收录了最近本人完成的一部分codeforces习题,不定期更新 codeforces 1132E Knapsack 注意到如果只使用某一种物品,那么这八种物品可以达到的最小相同重量为\(840\) 故 ...
- Codeforces Round #543 Div1题解(并不全)
Codeforces Round #543 Div1题解 Codeforces A. Diana and Liana 给定一个长度为\(m\)的序列,你可以从中删去不超过\(m-n*k\)个元素,剩下 ...
- Codeforces Round #539Ȟȟȡ (Div. 1) 简要题解
Codeforces Round #539 (Div. 1) A. Sasha and a Bit of Relax description 给一个序列\(a_i\),求有多少长度为偶数的区间\([l ...
- ZOJ 3684 Destroy 树的中心
中心节点就是树的中心,2遍dfs求到树的直径.而中心一定在直径上,顺着直径找到中心就够了. 然后能够一遍树形DP找到最小值或者二分+推断是否訪问到叶子节点. #include <iostream ...
随机推荐
- shell从入门到精通进阶之一:Shell基础知识
1.1 简介 Shell是一个C语言编写的脚本语言,它是用户与Linux的桥梁,用户输入命令交给Shell处理,Shell将相应的操作传递给内核(Kernel),内核把处理的结果输出给用户. 下面是处 ...
- 浅谈WPF中的MVVM框架--MVVMFoundation
先科普一下:什么是WPF,请看下图 微软对于WPF技术的构想是很宏大的,可惜普及率不高,不过如果你要做Windows客户端开发的话WPF技术还是值得一学的. 什么是MVVM模式 简单来说它是一种高级的 ...
- #12 Python函数
前言 矩形的面积 S = ab,只要知道任一矩形的的长和宽,就可以带入上式求得面积.这样有什么好处呢?一个公式,适用于全部矩形,一个公式,重复利用,减少了大脑的记忆负担.像这类用变量代替不变量的思想在 ...
- php 爬虫框架
发现两款不错的爬虫框架,极力推荐下: phpspider 一款优秀的PHP开发蜘蛛爬虫 官方下载地址:https://github.com/owner888/phpspider 官方开发手册:http ...
- linux部署二:网卡配置和Yum源的替换
一,初次登陆: 1.登陆(用root登陆)(1).账户名root(2).密码 ....2.工作界面切换A.Ctrl + alt + F1 : 图形化界面B.Ctrl + alt + F2----F6 ...
- 1.SDL介绍
01.什么是SDL SDL是微软提出的一种软件开发安全生命周期管理的一种最佳安全实践,全称为Security Development Lifecycle. SDL是微软软件开发安全保障流程,结合了软件 ...
- MongoDB 常用的数据备份梳理汇总
1.基于数据文件的备份 直接将原始的数据文件Copy至备份的地方,这个方法的优点是比较快,因为备份和恢复都不需要转换数据格式.缺点就是需要锁住数据库服务器,但是此方案通常备份是在从节点上进行,备份过程 ...
- MySQL分数排名同分并列与不并列查询
Scores表 | Id | Score | | 3.50 | | 3.65 | | 4.00 | | 3.85 | | 4.00 | | 3.65 | 并列 | Score | Rank | | | ...
- SQL SERVER-查询爆破sa密码的主机
drop table if exists #sql create table #sql ( Logdatae ), processinfo ), [text] varchar(max) ) go IN ...
- windows搭建golang环境
由于墙的存在,很多网址无法下载,推荐https://studygolang.com/dl去下载. windows需要配置几个环境变量,我是下载的压缩文件,所以需要自己配置,通过安装程序安装的应该不需要 ...