题意简述

给你一棵有根树,定义叶子为度数为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. 如何设计一个 RPC 系统

    本文由云+社区发表 RPC是一种方便的网络通信编程模型,由于和编程语言的高度结合,大大减少了处理网络数据的复杂度,让代码可读性也有可观的提高.但是RPC本身的构成却比较复杂,由于受到编程语言.网络模型 ...

  2. jquery父元素和子元素点击事件传递问题_不可把父元素的事件传递给子元素_事件无限循环传递

    前述:jquery中: 当一个元素的点击事件被触发时,会自动将该事件向父级元素逐级专递. 但是实际场景当中,我们可能会遇到需要在父级元素中定义点击事件,来触发特定子元素的点击事件,我就遇到了这么一个问 ...

  3. Wcf传递的参数实际不为空,但是接收时显示为空。

    问题原因:参数大小写不一致引起,服务端接收参数为空 客户端引用 服务端定义

  4. Asp.Net Core中使用MongoDB的入门教程,控制台程序使用 MongoDB

    内容来源  https://blog.csdn.net/only_yu_yy/article/details/78882446 首先,创建一个.Net Core的控制台应用程序.然后使用NuGet导入 ...

  5. Java开发笔记(五十七)因抽象方法而产生的抽象类

    前面介绍了类的常见用法,令人感叹面向对象的强大,几乎日常生活中的所有事物,都可以抽象成Java的基类及其子类.然而抽象操作也有副作用,就是某个抽象而来的行为可能是不确定的,比如半夜鸡叫,如果是公鸡则必 ...

  6. Redis面试点

      redis的数据结构有那些 字符串 String 字典:Hash 列表:List 集合:set 有序集合:sortedSet 如果大量的key设置在同一时间过期,一般需要注意什么 大量的key过期 ...

  7. springboot之配置文件

    springboot在加载配置文件的时候是有先后顺序的,了解加载配置文件的先后顺序,可以减少编写程序出现错误 1 springboot加载配置文件的先后顺序如下: SpringApplication将 ...

  8. bootstrap思考一

    bootstrap是一种热门的Web前端流行框架,如果要兼容PC端.手机端和响应式布局,那他一定是我的首选.bootstrap内容很多,功能强大,其中最好入门也是很重要的就是他的栅格系统.他有四个典型 ...

  9. 前端加密传输 crypto-js AES 加密和解密

    配置: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8 ...

  10. 基于 CODING 的 Spring Boot 持续集成项目

    本文作者:CODING 用户 - 廖石荣 持续集成的概念 持续集成(Continuous integration,简称 CI)是一种软件开发实践,即团队开发成员经常集成他们的工作,通常每个成员每天至少 ...