Codeforces 911F Tree Destruction
先把直径扣出来, 然后每个点都和直径的其中一端组合, 这样可以保证是最优的。
#include<bits/stdc++.h>
#define LL long long
#define fi first
#define se second
#define mk make_pair
#define PLL pair<LL, LL>
#define PLI pair<LL, int>
#define PII pair<int, int>
#define SZ(x) ((int)x.size())
#define ull unsigned long long using namespace std; const int N = 2e5 + ;
const int inf = 0x3f3f3f3f;
const LL INF = 0x3f3f3f3f3f3f3f3f;
const int mod = 1e9 + ;
const double eps = 1e-;
const double PI = acos(-); int n, deg[N], deptha[N], depthb[N];
vector<int> G[N];
queue<int> que;
vector<pair<PII, int>> vc; PII dfs(int u, int fa, int* depth) {
if(fa) depth[u] = depth[fa] + ;
else depth[u] = ;
PII ans = mk(depth[u], u);
for(auto& v : G[u]) {
if(v == fa) continue;
ans = max(ans, dfs(v, u, depth));
}
return ans;
} int main() {
scanf("%d", &n);
for(int i = ; i <= n; i++) {
int u, v; scanf("%d%d", &u, &v);
G[u].push_back(v);
G[v].push_back(u);
deg[u]++; deg[v]++;
}
int A = dfs(, , deptha).se;
int B = dfs(A, , deptha).se;
dfs(B, , depthb);
for(int i = ; i <= n; i++)
if(i != A && i != B && deg[i] == )
que.push(i);
LL ans = ;
while(!que.empty()) {
int u = que.front(); que.pop();
if(deptha[u] > depthb[u]) {
ans += deptha[u];
vc.push_back(mk(mk(A, u), u));
} else {
ans += depthb[u];
vc.push_back(mk(mk(B, u), u));
}
for(auto& v : G[u])
if(--deg[v] == )
que.push(v);
}
que.push(B);
while(!que.empty()) {
int u = que.front(); que.pop();
if(u == A) break;
ans += deptha[u];
vc.push_back(mk(mk(A, u), u));
for(auto& v : G[u])
if(--deg[v] == )
que.push(v);
}
printf("%lld\n", ans);
for(auto& t : vc) printf("%d %d %d\n", t.fi.fi, t.fi.se, t.se);
return ;
} /*
*/
Codeforces 911F Tree Destruction的更多相关文章
- Codeforces  911F Tree Destruction(贪心 && 树的直径)
		题目链接 Tree Destructi 题意 给定一棵树,每次可以选定树上的两个叶子,并删去其中的一个.答案每次加上两个选定的叶子之间的距离. 求最后答案的最大值. 首先求出树的某一条直径,令其端 ... 
- [Codeforces 911F] Tree Destruction 解题报告(贪心)
		题目链接: http://codeforces.com/contest/911/problem/F 题目大意: 给你一棵树,每次挑选这棵树的两个度数为1的点,加上他们之间的边数(距离),然后将其中一个 ... 
- Codeforces.911F.Tree Destruction(构造 贪心)
		题目链接 \(Description\) 一棵n个点的树,每次可以选择树上两个叶子节点并删去一个,得到的价值为两点间的距离 删n-1次,问如何能使最后得到的价值最大,并输出方案 \(Solution\ ... 
- CF911F Tree Destruction 解题报告
		CF911F Tree Destruction 题意翻译 给你一棵树,每次挑选这棵树的两个叶子,加上他们之间的边数(距离),然后将其中一个点去掉,问你边数(距离)之和最大可以是多少. 输入输出格式 输 ... 
- Codeforces 675D   Tree Construction Splay伸展树
		链接:https://codeforces.com/problemset/problem/675/D 题意: 给一个二叉搜索树,一开始为空,不断插入数字,每次插入之后,询问他的父亲节点的权值 题解: ... 
- Codeforces 570D TREE REQUESTS dfs序+树状数组  异或
		http://codeforces.com/problemset/problem/570/D Tree Requests time limit per test 2 seconds memory li ... 
- Codeforces 570D - Tree Requests【树形转线性,前缀和】
		http://codeforces.com/contest/570/problem/D 给一棵有根树(50w个点)(指定根是1号节点),每个点上有一个小写字母,然后有最多50w个询问,每个询问给出x和 ... 
- Codeforces 23E Tree
		http://codeforces.com/problemset/problem/23/E 题意:给一个树,求砍断某些边,使得所有联通块大小的乘积最大.思路:f[i][j]代表当前把j个贡献给i的父亲 ... 
- Codeforces 1092F Tree with Maximum Cost(树形DP)
		题目链接:Tree with Maximum Cost 题意:给定一棵树,树上每个顶点都有属性值ai,树的边权为1,求$\sum\limits_{i = 1}^{n} dist(i, v) \cdot ... 
随机推荐
- $Django Rest Framework-认证组件,权限组件 知识点回顾choices,on_delete
			一 小知识点回顾 #orm class UserInfo (models.Model): id = models.AutoField (primary_key=True) name = models. ... 
- Django 笔记(三)模版路径 ~ 静态引用
			1.模版路径: 在 settings,py 里的 TEMPLATES = [] 内添加一句代码拼接路径 'DIRS': [os.path.join(BASE_DIR, 'templates')] 有两 ... 
- C语言-社保工资查询系统
			一.简述 此次程序没有涉及函数,完成工资.保险和住房公积金税前税后的查询.工资和社保公积金算法是依据最新的北京标准计算. 五险一金标准: 税率: 1.输入编号1~6查询保险,然后再选择是依据税前工资还 ... 
- mixins,generics(ApiView)
			#生成序列化对象class BookModelSerizter(serializers.ModelSerializer): class Meta: model=Book fields='__all__ ... 
- Python-WEB前端-入门到进阶开发之路
			HTTP: Python-HTTP 概况 HTML: Python-HTML基础 Python-form表单标签 Python-HTML CSS 练习 CSS: Python-CSS入门 Python ... 
- 技术的热门度曲线:GHC
			全球最大的 IT 咨询公司高德纳(Gartner),有一个"技术热门度曲线"模型(Gartner Hype Cycle). 该模型认为,一门技术的发展要经历五个阶段. (1)启 ... 
- Socket通讯成功案例
			Socket通讯案例 #region 服务端 //int port = 1234; //string host = "127.0.0.1"; //IPAddress ip = IP ... 
- Spark Streaming 实现思路与模块概述
			一.基于 Spark 做 Spark Streaming 的思路 Spark Streaming 与 Spark Core 的关系可以用下面的经典部件图来表述: 在本节,我们先探讨一下基于 Spark ... 
- Java 获取当前系统的时间
			获取当前系统的时间,每隔一秒,打印一次. import java.util.Date; public class TestDate { public static void main(String[] ... 
- SCSS 使用@each 方法循环遍历数组颜色并给li赋值
			$list-bg:red,orange,blue,skyblue; ul{ >li{ height: 30px; @each $c in $list-bg{ $i:index($list-bg, ... 
