cf701E Connecting Universities
Treeland is a country in which there are n towns connected by n - 1 two-way road such that it's possible to get from any town to any other town.
In Treeland there are 2k universities which are located in different towns.
Recently, the president signed the decree to connect universities by high-speed network.The Ministry of Education understood the decree in its own way and decided that it was enough to connect each university with another one by using a cable. Formally, the decree will be done!
To have the maximum sum in the budget, the Ministry decided to divide universities into pairs so that the total length of the required cable will be maximum. In other words, the total distance between universities in k pairs should be as large as possible.
Help the Ministry to find the maximum total distance. Of course, each university should be present in only one pair. Consider that all roads have the same length which is equal to 1.
The first line of the input contains two integers n and k (2 ≤ n ≤ 200 000, 1 ≤ k ≤ n / 2) — the number of towns in Treeland and the number of university pairs. Consider that towns are numbered from 1 to n.
The second line contains 2k distinct integers u1, u2, ..., u2k (1 ≤ ui ≤ n) — indices of towns in which universities are located.
The next n - 1 line contains the description of roads. Each line contains the pair of integers xj and yj (1 ≤ xj, yj ≤ n), which means that the j-th road connects towns xj and yj. All of them are two-way roads. You can move from any town to any other using only these roads.
Print the maximum possible sum of distances in the division of universities into k pairs.
7 2
1 5 6 2
1 3
3 2
4 5
3 7
4 3
4 6
6
9 3
3 2 1 6 5 9
8 9
3 2
2 7
3 4
7 6
4 5
2 1
2 8
9
The figure below shows one of possible division into pairs in the first test. If you connect universities number 1 and 6 (marked in red) and universities number 2 and 5 (marked in blue) by using the cable, the total distance will equal 6 which will be the maximum sum in this example.

给定树上2k个特殊点,把它分成k对,使得k对之间的距离之和最大
画个图就知道,显然尽可能取跨度最大的点是更优的。
假如树上某个节点i下特殊点数是son[i],那么(i,fa[i])这条边应当被取到min(son[i],2k-son[i])次
因为要使得跨度尽量大,肯定要让i的儿子绕远路跟i子树外面的配对
#include<cstdio>
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<algorithm>
#include<cmath>
#include<queue>
#include<deque>
#include<set>
#include<map>
#include<ctime>
#define LL long long
#define inf 0x7ffffff
#define pa pair<int,int>
using namespace std;
inline LL read()
{
LL x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
inline void write(LL a)
{
if (a<){printf("-");a=-a;}
if (a>=)write(a/);
putchar(a%+'');
}
int n,k,cnt;
int dep[];
int fa[];
int son[];
int head[];
bool mrk[];
bool ask[];
LL f[];
struct edge{
int to,next;
}e[];
inline void ins(int u,int v)
{
e[++cnt].to=v;
e[cnt].next=head[u];
head[u]=cnt;
}
inline void insert(int u,int v)
{
ins(u,v);
ins(v,u);
}
inline void dfs(int x)
{
if (mrk[x])return;
if (ask[x])son[x]=;
mrk[x]=;
for (int i=head[x];i;i=e[i].next)
{
if (!mrk[e[i].to])
{
dep[e[i].to]=dep[x]+;
fa[e[i].to]=x;
dfs(e[i].to);
son[x]+=son[e[i].to];
}
}
}
inline void dfs2(int x)
{
if (mrk[x])return;mrk[x]=;
if (*son[x]<=k)f[x]=son[x];else f[x]=k-son[x];
for (int i=head[x];i;i=e[i].next)
{
if (!mrk[e[i].to])
{
dfs2(e[i].to);
f[x]+=f[e[i].to];
}
}
}
int main()
{
n=read();k=read();k*=;
for(int i=;i<=k;i++)
{
int x=read();
ask[x]=;
}
for (int i=;i<n;i++)
{
int x=read(),y=read();
insert(x,y);
}
dfs();
memset(mrk,,sizeof(mrk));
dfs2();
printf("%lld\n",f[]);
}
cf701E
cf701E Connecting Universities的更多相关文章
- Codeforces Round #364 (Div. 2) E. Connecting Universities
		E. Connecting Universities time limit per test 3 seconds memory limit per test 256 megabytes input s ... 
- Connecting Universities
		Connecting Universities Treeland is a country in which there are n towns connected by n - 1 two-way ... 
- Codeforces Round #364 (Div. 2) E. Connecting Universities (DFS)
		E. Connecting Universities time limit per test 3 seconds memory limit per test 256 megabytes input s ... 
- codeforces 701E E. Connecting Universities(树的重心)
		题目链接: E. Connecting Universities time limit per test 3 seconds memory limit per test 256 megabytes i ... 
- Codeforces 701E Connecting Universities 贪心
		链接 Codeforces 701E Connecting Universities 题意 n个点的树,给你2*K个点,分成K对,使得两两之间的距离和最大 思路 贪心,思路挺巧妙的.首先dfs一遍记录 ... 
- Codeforces 700B Connecting Universities - 贪心
		Treeland is a country in which there are n towns connected by n - 1 two-way road such that it's poss ... 
- cf 700 B  Connecting Universities
		题意:现在给以一棵$n$个结点的树,并给你$2k$个结点,现在要求你把这些节点互相配对,使得互相配对的节点之间的距离(路径上经过边的数目)之和最大.数据范围$1 \leq n \leq 200000, ... 
- codeforces 700B Connecting Universities 贪心dfs
		分析:这个题一眼看上去很难,但是正着做不行,我们换个角度:考虑每条边的贡献 因为是一棵树,所以一条边把树分成两个集合,假如左边有x个学校,右边有y个学校 贪心地想,让每条边在学校的路径上最多,所以贡献 ... 
- Codeforces 700B Connecting Universities(树形DP)
		[题目链接] http://codeforces.com/problemset/problem/700/B [题目大意] 给出 一棵n个节点的树, 现在在这棵树上选取2*k个点,两两配对,使得其配对的 ... 
随机推荐
- More helpful Cocos2d and Gaming macros
			More helpful Cocos2d and Gaming macros Here are w few macros that i wrote to make the code more read ... 
- 如何在ABAP里用函数式编程思想打印出非波拉契Fibonacci(数列)
			在JavaScript里可以用ES6提供的FunctionGenerator这种黑科技来打印非波拉契数列,具体细节参考我这篇文章. 在ABAP里也有很多种方式实现这个需求. 下面这个report分别用 ... 
- 导致实例逐出的五大问题 (文档 ID 1526186.1)
			适用于: Oracle Database - Enterprise Edition - 版本 10.2.0.1 到 11.2.0.3 [发行版 10.2 到 11.2]本文档所含信息适用于所有平台 用 ... 
- codeforce Gym 100203I 	I WIN (网络流)
			把'I'拆成容量为1一条边,一个入点一个出点,入点和相邻的'W'连一条容量为1的边,出点和相邻的'N'连一条容量为1,所有的'W'和源点连一条容量为1边,所有的'N'和汇点连一条容量为1的边,表示只能 ... 
- 2018_oakland_linuxmalware
			2018年oakland论文:理解linux恶意软件 论文地址:http://www.s3.eurecom.fr/~yanick/publications/2018_oakland_linuxmalw ... 
- 不安装oracle客户端用sqlplus连接数据库
			在不安装oracle客户端情况下用sqlplus连接数据库: 1.去官网下载 http://www.oracle.com/technetwork/topics/winx64soft-089540.ht ... 
- sublime text 3143 最新激活方法
			1)输入激活码 —– BEGIN LICENSE —– TwitterInc 200 User License EA7E-890007 1D77F72E 390CDD93 4DCBA022 FAF60 ... 
- WINDOWS下使用Mysql 中碰到的问题记录
			问题:在cmd中输入net stop mysql反馈“服务名无效” win+R打开运行窗口,输入 services.msc 查看其中mysql的服务名,比如我的是叫做MySQL80 让我们继续回到最开 ... 
- java发送email一般步骤
			java发送email一般步骤 一.引入javamail的jar包: 二.创建一个测试类,实现将要发送的邮件内容写入到计算机本地,查看是否能够将内容写入: public static void mai ... 
- 如何用纯 CSS 创作一个蝴蝶标本展示框
			效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/xzgZzQ 可交互视频教 ... 
