Codeforces 734E Anton and Tree(缩点+树的直径)
题目链接: Anton and Tree
题意:给出一棵树由0和1构成,一次操作可以将树上一块相同的数字转换为另一个(0->1 , 1->0),求最少几次操作可以把这棵数转化为只有一个数字的一棵数。
题解:首先一次可以改变一片数字,那么进行缩点后就变成了每次改变一个点。缩完点后这棵数变成了一棵相邻节点不同,0和1相交叉的一棵树。然后一棵树的直径上就是
这种情况,相当于从中间开始操作,总共操作(L+1)/2次。关于其他的分支一定会在直径的改变过程中完成改变。
#include<bits/stdc++.h>
using namespace std;
const int MAX_N = 2e5+;
const long long INF = 1e9+;
typedef pair<int,int> P;
int N,M,T;
vector<P> V;
int dir[MAX_N];
int vec[MAX_N];
int father[MAX_N];
int vis[MAX_N];
vector<int> tran[MAX_N];
int start,deep;
void init(){
for(int i=;i<MAX_N;i++){
dir[i] = i;
tran[i].clear();
vis[i] = ;
}
V.clear();
start = -;
deep = ;
}
int find_f(int x){
if(x == dir[x]) return x;
return dir[x] = find_f(dir[x]);
}
void bfs(int pos,int deepth){
if(deepth > deep){
deep = deepth;
start = pos;
//cout<<"....."<<deepth<<endl;
}
vis[pos] = ;
for(int i=;i<tran[pos].size();i++){
if(!vis[tran[pos][i]]) bfs(tran[pos][i],deepth+);
}
return ;
}
int main()
{
while(cin>>N){
init();
for(int i=;i<=N;i++){
scanf("%d",&vec[i]);
}
for(int i=;i<N-;i++){
int a,b;
scanf("%d%d",&a,&b);
int fa = find_f(a);
int fb = find_f(b);
if(vec[fa] == vec[fb] ) dir[fb] = dir[fa];
else V.push_back(P(fa,fb));
}
for(int i=;i<=N;i++){
father[i] = find_f(i);
}
for(int i=;i<V.size();i++){
P p = V[i];
//cout<<father[p.first]<<"...."<<father[p.second]<<endl;
tran[father[p.first]].push_back(father[p.second]);
tran[father[p.second]].push_back(father[p.first]);
start = father[p.first];
}
if(start == -) {
cout<<<<endl;
}
else{
bfs(start,);
deep = ;
for(int i=;i<=N;i++) vis[i] = ;
bfs(start,);
cout<<(deep+)/<<endl;
} }
return ;
}
/* */
Codeforces 734E Anton and Tree(缩点+树的直径)的更多相关文章
- Codeforces Round #379 (Div. 2) E. Anton and Tree 缩点 树的直径
传送门 题意: 这道题说的是在一颗有两种颜色的树上,每操作一个节点,可以改变这个节点颜色和相邻同色节点的颜色.问最少操作次数,使得树上颜色相同. 思路: 先缩点,把相同的颜色的相邻节点缩在一起.再求出 ...
- Codeforces 734E. Anton and Tree 搜索
E. Anton and Tree time limit per test: 3 seconds memory limit per test :256 megabytes input:standard ...
- CodeForces 734E Anton and Tree
$dfs$缩点,树形$dp$. 首先将连通块缩点,缩点后形成一个黑白节点相间的树.接下来的任务就是寻找一个$root$,使这棵树以$root$为根,树的高度是最小的(也就是一层一层染色).树形$dp$ ...
- Codeforces Round #379 (Div. 2) E. Anton and Tree 缩点 直径
E. Anton and Tree 题目连接: http://codeforces.com/contest/734/problem/E Description Anton is growing a t ...
- Codeforces Round #379 (Div. 2) E. Anton and Tree —— 缩点 + 树上最长路
题目链接:http://codeforces.com/contest/734/problem/E E. Anton and Tree time limit per test 3 seconds mem ...
- codeforces GYM 100114 J. Computer Network tarjan 树的直径 缩点
J. Computer Network Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/gym/100114 Des ...
- codeforces GYM 100114 J. Computer Network 无相图缩点+树的直径
题目链接: http://codeforces.com/gym/100114 Description The computer network of “Plunder & Flee Inc.” ...
- HDU4612 Warm up 边双(重边)缩点+树的直径
题意:一个连通无向图,问你增加一条边后,让原图桥边最少 分析:先边双缩点,因为连通,所以消环变树,每一个树边都是桥,现在让你增加一条边,让桥变少(即形成环) 所以我们选择一条树上最长的路径,连接两端, ...
- hdu 4612 Warm up 有重边缩点+树的直径
题目链接 Warm up Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Others)Tot ...
随机推荐
- python 使用else代替状态变量
翻看公司的代码文档,在代码风格文档中,写着:为了提高代码的可维护性,代码中减少flag这类状态变量的使用.这个问题,平时确实没有想过,面对这种需求时,第一反应就是使用flag标记状态.那么使用什么样的 ...
- LeetCode 题解之Linked List Cycle II
1.题目描述 2.问题分析 使用快慢指针方法判断链表是否有环,然后寻找环开始的节点. 3.代码 ListNode *detectCycle(ListNode *head) { if( head == ...
- TFS命令行操作
前言 本文主要介绍如何通过TFS(Team Foundation Server)命令行强制解锁(UnDo)项目成员对项目文件的占用. 正文 在多人同时开发项目的时候,如果遇到项目组成员独占签出文件后未 ...
- pycharm的常用快捷键
使用pycharm写代码时,如果有错误,一般代码右边会有红色标记. 1,写代码时忘记导入模块,可以使用快捷键 Alt + Enter 自动导入模块.() 再倒入模块之前,需要现在pycharm ...
- Azure 中虚拟机的备份和还原选项
可以通过定期创建备份来保护数据. 有多个备份选项可用于 VM,具体取决于使用案例. Azure 备份 若要备份运行生产工作负荷的 Azure VM,请使用 Azure 备份. Azure 备份对 Wi ...
- Oracle EBS AR 客户API
------------------------------------ 1. Set Environment ------------------------------------ -- 1a. ...
- js拼接table查询信息部分
其一: $("#datagrid").empty(); var a=0; <order-rows> a++; $("#datagrid").appe ...
- fedora 开启 apache 并 开启目录浏览模式
在内网中 暂时需要一台 文件 服务器,所以准备安装一台 http服务器并开启目录访问权限.这次使用 apache 在 fedora 28 机器上: 因为 fedora 28 已经包含 httpd 软件 ...
- python 进程池pool
进程池子 当你成千上万的业务需要创建成千上万的进程时,我们可以提前定义一个进程池 from multiprocessing import Pool p = Pool(10) #进程池创建方式,类似空任 ...
- October 10th 2017 Week 41st Tuesday
If you focus on what you left behind you will never see what lies ahead. 如果你只顾回头看,那么你永远也看不见前方有什么. Ye ...