题意简述

给你一棵有根树,定义叶子为度数为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的更多相关文章

  1. CF1120D Power Tree(构造题,差分,最小生成树)

    很有趣的一道题. 首先可以对每个叶子进行编号.按照DFS到的顺序即可.(假设从 $1$ 到 $k$) 然后对每个点求出它管辖的所有叶子的编号.因为是DFS序所以这一定是个区间.设点 $u$ 的这个区间 ...

  2. Codeforces 1120D Power Tree [最小生成树]

    洛谷 Codeforces 这题怎么一个中文题解都没有,是不是你们都认为太水了-- 思路 显然可以用dfs序把每个节点变成给一个区间的叶子节点加上某个数. 显然把叶子序列差分一下变为\(a_1,a_2 ...

  3. [CF607D]Power Tree

    题目大意: 一棵树初始只有一个编号为$1$的权值为$w_1$的根.$q(q\le2\times10^5)$次操作,每次可以给出$v,w(w<10^9)$,新建一个结点作为$v$的子结点,权值为$ ...

  4. Solution -「树上杂题?」专练

    主要是记录思路,不要被刚开始错误方向带偏了 www 「CF1110F」Nearest Leaf 特殊性质:先序遍历即为 \(1 \to n\),可得出:叶子节点编号递增或可在不改变树形态的基础上调整为 ...

  5. cf Round 607

    A.Chain Reaction(DP+二分) 题意:一排有n个灯塔,每个灯塔给出坐标xi和力量yi,每次从最右边依次点亮灯塔,每点亮一个灯塔,它左边的距离它yi范围内的灯塔将受到损坏.现在允许在最右 ...

  6. codeforces选做

    收录了最近本人完成的一部分codeforces习题,不定期更新 codeforces 1132E Knapsack 注意到如果只使用某一种物品,那么这八种物品可以达到的最小相同重量为\(840\) 故 ...

  7. Codeforces Round #543 Div1题解(并不全)

    Codeforces Round #543 Div1题解 Codeforces A. Diana and Liana 给定一个长度为\(m\)的序列,你可以从中删去不超过\(m-n*k\)个元素,剩下 ...

  8. Codeforces Round #539&#542&#543&#545 (Div. 1) 简要题解

    Codeforces Round #539 (Div. 1) A. Sasha and a Bit of Relax description 给一个序列\(a_i\),求有多少长度为偶数的区间\([l ...

  9. ZOJ 3684 Destroy 树的中心

    中心节点就是树的中心,2遍dfs求到树的直径.而中心一定在直径上,顺着直径找到中心就够了. 然后能够一遍树形DP找到最小值或者二分+推断是否訪问到叶子节点. #include <iostream ...

随机推荐

  1. Python机器学习笔记 使用scikit-learn工具进行PCA降维

    之前总结过关于PCA的知识:深入学习主成分分析(PCA)算法原理.这里打算再写一篇笔记,总结一下如何使用scikit-learn工具来进行PCA降维. 在数据处理中,经常会遇到特征维度比样本数量多得多 ...

  2. 解析JavaScrip之对象属性

    对于面向对象编程语言(如java,.net,php,python等)来说,其最大的特点在于“面向对象”,而"面向对象"较为显著的特征便是:封装,继承,多态.借助”面向对象“的这些特 ...

  3. BEAMER中 Package Listings Warning: Text dropped after begin of listing on input line xx

    Latex Beamer 模板 frame 中使用 listings package时总出现标题所示错误,无法前进.解决方法是在\begin{frame}后加上一个选项,即:\begin{frame} ...

  4. Windows系统 应用或游戏 打开出现0xc000007b错误 解决方法

    1.使用directX修复工具(推荐) 标准版 增强版 标准版备用地址 增强版备用地址 2. 重新安装DirectX 9.0 安装包(安装包体积大) 微软官方离线安装包 摘录CSDN博客 运行游戏时出 ...

  5. Qt Creator的下载和安装

    原文:https://blog.csdn.net/weixin_38090427/article/details/83827678 一,Qt和Qt Creator的区别 Qt是C++的一个库,或者说是 ...

  6. Django验证码【附源码】

    一.安装依赖 CentOS 第一步: yum install python-devel 第二步: yum install freetype-devel libjpeg-devel libpng-dev ...

  7. java框架之springboot

    快速入门 一.helloworld示例 二.springboot单元测试 三.springboot热部署 web开发 整合redis thymeleaf使用 spring-data-jpa使用 整合m ...

  8. jQuery 父iframe与子iframe 相互调用传值

    来自:https://blog.csdn.net/wd4871/article/details/50517597 侵删 父页面中的iframe :如下 <iframe name="su ...

  9. 【20190415】JavaScript-事件流与stopPropagation()、stopImmediatePropagation()的误区解析

    这两天仔细看了一下MDN上关于事件流机制和相关方法的文档,发现有个很大的误区.过去我一直以为stopPropagation()就是用来阻止事件冒泡的,甚至很多博客和菜鸟教程上都是这样写的.但实际上文档 ...

  10. 【20190228】JavaScript-获取子元素

    在写JavaScript的时候发现了一个获取子节点的坑,如以下的html结构 <div id="parent"> <div>1</div> &l ...