codeforces734E
题目连接:http://codeforces.com/contest/734/problem/E
3 seconds
256 megabytes
standard input
standard output
Anton is growing a tree in his garden. In case you forgot, the tree is a connected acyclic undirected graph.
There are n vertices in the tree, each of them is painted black or white. Anton doesn't like multicolored trees, so he wants to change the tree such that all vertices have the same color (black or white).
To change the colors Anton can use only operations of one type. We denote it as paint(v), where v is some vertex of the tree. This operation changes the color of all vertices u such that all vertices on the shortest path from v to u have the same color (including v and u). For example, consider the tree

and apply operation paint(3) to get the following:

Anton is interested in the minimum number of operation he needs to perform in order to make the colors of all vertices equal.
The first line of the input contains a single integer n (1 ≤ n ≤ 200 000) — the number of vertices in the tree.
The second line contains n integers colori (0 ≤ colori ≤ 1) — colors of the vertices. colori = 0 means that the i-th vertex is initially painted white, while colori = 1 means it's initially painted black.
Then follow n - 1 line, each of them contains a pair of integers ui and vi (1 ≤ ui, vi ≤ n, ui ≠ vi) — indices of vertices connected by the corresponding edge. It's guaranteed that all pairs (ui, vi) are distinct, i.e. there are no multiple edges.
Print one integer — the minimum number of operations Anton has to apply in order to make all vertices of the tree black or all vertices of the tree white.
题目大意:有一棵树,有黑白两种颜色,每个节点为黑色或白色,每次变换使得相连的同色节点全部变成另一种颜色,求使树变成单色(纯黑或纯白)所需的最少操作数。
解题思路:
刚开始忽略了改变颜色后连同块的大小会改变,用并查集做了,结果当然WA,后来想到会改变,所以用dfs。
第一次dfs缩点,把连通块缩为一点,构成一个新图,方便处理。
缩点完成后的图就变成了黑白交替出现的一棵树,改变一个节点就相当于把它和与他直接相连的所有节点缩为一点,最后的结果为该树的最长路径/2。
写一下自己想的弱鸡证明过程;
1.首先证明,操作次数只与最长路径有关。
假设有一棵树(称之为完全树),在它的最长路径上的所有节点都连有在保证该路径是最长路径的前提下可连的最多节点,显然,此种情况下操作次数不会大于只有最长路的操作次数,因为必须保证最长链完成修改。另外显然,经过缩点得到的所有可能的树的操作次数小于等于完全树,所以可得,操作次数只与最长路径有关。
2.证明结果为最长路径的1/2。
只考虑其最长路径,假设最长路径节点数n为奇数,则相当于每次操作减少两节点,直至最后剩下一个节点,设操作数为x,则有:n-2x=1,解得x=(n-1)/2;
假设n为偶数,则最后一次操作相当于只消除一个节点,则有n-2(x-1)-1=1,解得 =n/2
综合可得,x=n/2(整数除法)
代码如下:
#include<bits/stdc++.h>
using namespace std;
vector <],g[];
];
]={};
,maxp;
void dfs1(int n,int s)
{
if(n>N||vis[n])
return;
vis[n]=;
if(c[n]!=c[s])
{
g[n].push_back(s);
g[s].push_back(n);
s=n;
}
;i<G[n].size();i++)
{
dfs1(G[n][i],s);
}
}
void dfs2(int n,int dis)
{
if(vis[n])
return;
vis[n]=;
if(dis>maxx)
{
maxx=dis;
maxp=n;
}
;i<g[n].size();i++)
dfs2(g[n][i],dis+);
}
int main()
{
int x,y;
cin>>N;
;i<=N;i++)
scanf("%d",&c[i]);
;i<N;i++)
{
scanf("%d%d",&x,&y);
G[x].push_back(y);
G[y].push_back(x);
}
dfs1(,);
memset(vis,,sizeof(vis));
dfs2(,);
memset(vis,,sizeof(vis));
dfs2(maxp,);
cout<<maxx/<<endl;
}
codeforces734E的更多相关文章
- CodeForces-734E Anton and Tree 树的直径
题目大意: 给定一棵有n个节点的树,有黑点白点两种节点. 每一次操作可以选择一个同种颜色的联通块将其染成同一种颜色 现在给定一个初始局面问最少多少步可以让树变为纯色. 题解: 首先我们拿到这棵树时先将 ...
随机推荐
- setCharacterEncoding 是在request.getParameter获取参数之前 设置request的编码格式 一步到位
setCharacterEncoding 是在request.getParameter获取参数之前 设置request的编码格式 一步到位
- Android逆向之旅---静态方式分析破解视频编辑应用「Vue」水印问题
一.故事背景 现在很多人都喜欢玩文艺,特别是我身边的UI们,拍照一分钟修图半小时.就是为了能够在朋友圈显得逼格高,不过的确是挺好看的,修图的软件太多了就不多说了,而且一般都没有水印啥的.相比较短视频有 ...
- 【CF edu 30 C. Strange Game On Matrix】
time limit per test 1 second memory limit per test 256 megabytes input standard input output standa ...
- 解决echarts中X轴文字过长的问题。【转】
axisLabel: { interval: , formatter:function(value) { debugger var ret = "";//拼接加\n返回的类目项 ; ...
- Educational Codeforces Round 55:B. Vova and Trophies
B. Vova and Trophies 题目链接:https://codeforc.es/contest/1082/problem/B 题意: 给出一个“GS”串,有一次交换两个字母的机会,问最大的 ...
- eclipse中的debug按钮组突然找不到了,找回方法
- 怎么利用idea自带的工具,不需要 重启tomcat或则其他服务,js代码自动生效
idea中有一个工具:可以直接upload,能让你修改的界面直接可以看到,不需要重启服务. 依次点击的按钮如下: 点击进入的界面这个填的只是一个示例,在各位的电脑上肯定不行,大家依据实际情况填写.
- 对比append插入数据产生的redo量
--版本信息 SELECT * FROM v$version; Oracle - Prod PL - Production CORE Production TNS - Production NLSRT ...
- lesson 4 再谈继承多态,抽象类和接口
再谈多态,抽象类和接口 上一次博客已经概念性的概述了继承多态,抽象类和接口,这次来具体的谈一谈他们之间的联系和需要注意的地方. 一.继承和多态:Inheritance (继承) & Polym ...
- 3中转换JSON数据的方式
一:前言 来公司一个星期,把最近做的东西梳理下,并把觉得有必要的知识点记载下,现在传数据很多都是用JSON来传数据,所以我就找了集中传json的方式,其实是有五种的,但是有一个我没有用过,太陌生了,上 ...