cf 701 E - Connecting Universities
Descrition
给你一颗\(n\le 2*10^5\)个点的树, 有\(2*k(2k\le n)\)座大学座落在点上
(任二大学不在同一个点)
求一种两两匹配的方案, 使得距离和最大
即\[maximize~\{~\sum_{each~pair~(x,y)} dis(x,y)~\}~\]
Solution 1
(1) 化简一下我们相当于要最小化 两两lca的深度和
我们先把这2k所大学按dfn序从小到大排好, 把前k个称为A部分, 后k个称为B部分
(2) 所有匹配均为\(A-B\)匹配
如果存在一个\(A-A'\)匹配, 那么一定也会存在一个$B-B' $匹配
此时通过交换匹配, 显然一定可以变优
(3) 引理: dfn区间[\(x,y\)]的公共lca 为 \(lca(x,r)\) 或 \(lca(l,r)\), 其中\(x\le l \le r\le y\)
首先[x,y]的公共lca为点x,点y的lca是显然的
\(x\to r\)相当于走到子树或者向上回溯然后往下走
如果\(x-r\)路径没有跨过lca, 如图1, 那么r-y就必定会跨过lca
如果\(x-r\)路径跨国了lca, 如图2, 那么引理成立

(4) 若\(x<y\in A\), 那么\(x' < y'\)
如果存在\(x<y<y'<x'\) , 我们可以交换匹配变成\(x-y', y-x'\), 解不会变差
\(lca(x, x') < one~of~lca(x, y')~and~lca(y, x')\)
\(lca(y, y') < both~of~lca(x, y')~and~lca(y, x')\)
(5) 匹配为\(i\to i+k\)
根据(2) , \(1\)至少要匹配到\(1+k\)的位置
根据\((4)\), 必须要\(i\to i+k\), 才能保证匹配位置足够选择
Solution 2
考虑每条边\(fa\to x\)
记\(x\)子树内有\(sub[x]\)所大学
那么\(x\)子树外有\(2k-sub[x]\)所大学
结论: 每条边被匹配恰 \(min(sub[x], 2k- sub[x])\)次
首先, 不可能超过这个次数
然后, 如果小于, 那么子树内部有一对匹配, 子树外部有一对匹配
通过交换匹配一定可以使得距离变长
知道每条边被匹配多少次后, 貌似可以用启发式合并vec的方式构造解
(行吧原题不要求构造解)
cf 701 E - Connecting Universities的更多相关文章
- codeforces 701 E. Connecting Universities(树+ 边的贡献)
题目链接:http://codeforces.com/contest/701/problem/E 题意:有n个城市构成一棵树,一个城市最多有一个学校,这n个城市一共2*k个学校,要对这2*k个学校进行 ...
- cf 700 B Connecting Universities
题意:现在给以一棵$n$个结点的树,并给你$2k$个结点,现在要求你把这些节点互相配对,使得互相配对的节点之间的距离(路径上经过边的数目)之和最大.数据范围$1 \leq n \leq 200000, ...
- 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 ...
- cf701E Connecting Universities
Treeland is a country in which there are n towns connected by n - 1 two-way road such that it's poss ...
随机推荐
- Oracle 表的连接方式
1. 连接说明 ① Oracle一次只能连接两个表.不管查询中有多少个表,Oracle 在连接中一次仅能操作两张表. ② 当执行多个表的连接时,优化器从一个表开始,将它与另一个表连接:然后将中间结果与 ...
- iOS 反射函数: performSelector, NSInvocation, objc_msgSend
当我们有方法名和参数列表,想要动态地给对象发送消息,可用通过反射函数机制来实现,有两种常用的做法: 一.performSelector - (id)performSelector:(SEL)aSele ...
- GNU C中__attribute__
__attribute__基本介绍: 1. __attribute__ 可以设置函数属性.变量属性和类型属性. 2. __attribute__ 语法格式为:__attribute__ ((attri ...
- Java 对数组的筛选
在Java里面 一般对一个数组进行筛选,去剔除一些元素,一般做法是用临时数组来存储,把符合条件的元素加入到新数组中,虽然数组有移除的方法但是 是线程不安全的: 而用迭代器Iterator,可以在遍历的 ...
- 八、MySQL 数据类型
MySQL 数据类型 MySQL中定义数据字段的类型对你数据库的优化是非常重要的. MySQL支持多种类型,大致可以分为三类:数值.日期/时间和字符串(字符)类型. 数值类型 MySQL支持所有标准S ...
- Girls and Boys-hdu 1068
Girls and Boys Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- Problem I. Count - HDU - 6434(欧拉函数)
题意 给一个\(n\),计算 \[\sum_{i=1}^{n}\sum_{j=1}^{i-1}[gcd(i + j, i - j) = 1]\] 题解 令\(a = i - j\) 要求 \[\sum ...
- [BZOJ1597][Usaco2008 Mar]土地购买(斜率优化)
Description 农夫John准备扩大他的农场,他正在考虑N (1 <= N <= 50,000) 块长方形的土地. 每块土地的长宽满足(1 <= 宽 <= 1,000, ...
- 2、大O表示法
一.大O表示法 大O表示法不是一种算法.它是用来表示一个算法解决问题的速度的快慢.一般我们描述一件事情完成的快慢是用时间描述的,比如说我完成一道计算题用了多少分钟.但算法的运算是很难用准确的时间来描述 ...
- Diycode开源项目 磁盘图片缓存+自定义webViewClient+图片点击js方法
1.磁盘图片缓存器DiskImageCache 1.1.这个类很多情况都可能用的到,耦合性很低,所以分开讲. 源代码: /* * Copyright 2017 GcsSloop * * License ...