原题链接 Codeforces Global Round 16 E. Buds Re-hanging

首先想到,如果我们把一个\(buds\)挂到一个叶子上,那么会使得叶子总数减\(1\)。

还有就是如果我们可以把这个树搞成一条链,那么总叶子数一定是最少的,就是让树“越瘦越好”。

如果原来一个\(buds\)挂在一个没有其他孩子的结点上,我们拿走这个\(buds\)之后会使得总叶子数加\(1\),我们称这个结点为 \(\alpha\),如果一个buds挂在一个有其他孩子的节点上,那么拿走这个\(buds\)总叶子数不会改变,我们称这个结点为\(\beta\)。

我们考虑把所有的\(buds\)全挂在\(root\)上,那么这样做会使结果变坏吗?当然不会

  1. 如果一个\(buds\)挂在一个\(\beta\)结点上,那么拿走后总叶子数不变。
  2. 如果一个\(buds\)挂在一个\(\alpha\)结点上,那么拿走后总叶子数会加\(1\),但是我们完全可以再搞一个\(buds\)挂在\(\alpha\)结点上,这样就叶子总数又减少了。

全挂在\(root\)上之后,我们考虑再将其变成一条链子,怎么变呢?

首先设总结点数为\(n\),\(buds\)数为\(k\),那么由于所有\(buds\)全挂在了\(root\)上,那么现在的叶子数就是\(n - k - 1\)

情况一:如果\(root\)上有一个叶子结点, 那么我们不妨把\(k\)个\(buds\)依次全挂到这个叶子节点上,那么我们挂一次少一个叶子,那么答案就是\(n - k - 1 - k\)

情况二:如果\(root\)上没有叶子结点,那么我们就把\(k - 1\)个\(buds\)都依次挂到一个\(bud\)上就行,那么答案就是\(n - k - 1 - (k - 1)\)

代码:

// Problem: E. Buds Re-hanging
// Contest: Codeforces - Codeforces Global Round 16
// URL: https://codeforces.com/contest/1566/problem/E
// Memory Limit: 256 MB
// Time Limit: 1000 ms
//
// Powered by CP Editor (https://cpeditor.org) #include <bits/stdc++.h> using namespace std; const int N = 2E5 + 10;
vector<int> g[N];
int type[N]; //0 -- root, 1 -- leaf, 2 -- bud void dfs(int u, int fa) {
bool leaf = false;
for (auto v : g[u]) {
if (v == fa) continue;
dfs(v, u);
if (type[v] == 1) leaf = true;
} if (u != fa) {
if (!leaf) type[u] = 1;
else type[u] = 2;
}
} int main() {
int _; scanf("%d", &_);
while (_--) {
int n;
scanf("%d", &n);
for (int i = 1; i <= n; i++) g[i].clear();
memset(type, -1, sizeof type); for (int i = 1; i <= n - 1; i++) {
int u, v;
scanf("%d%d", &u, &v);
g[u].push_back(v);
g[v].push_back(u);
} type[1] = 0;
dfs(1, 1); bool rHas_leaf = false;
for (auto it: g[1]) {
if (type[it] == 1) {
rHas_leaf = true;
break;
}
} //将所有buds直接接到根上,这样在把buds拿走接到一个leaf上只会减少一个leaf数,而不会增加leaf
//设buds有k个,那么现在叶子节点数n - k - 1
/*
如果根有叶子结点,我们选择将k个buds顺次接到这个叶子结点上,接一次减少1,所以答案n - k - 1 - k
如果根没有叶子结点,那么将其他buds接到其中一个bud上去,那么答案n - k - 1 - (k - 1)
*/
int k = 0;
for (int i = 1; i <= n; i++) {
if (type[i] == 2) k += 1;
} if (rHas_leaf) printf("%d\n", n - 2 * k - 1);
else printf("%d\n", n - 2 * k);
} return 0;
}

Codeforces 1566E Buds Re-hanging的更多相关文章

  1. CodeForces 构造题专项解题报告

    CodeForces 构造题专项解题报告 \(\newcommand \m \mathbf\)\(\newcommand \oper \operatorname\) \(\text{By DaiRui ...

  2. Codeforces Round #283 (Div. 2) A ,B ,C 暴力,暴力,暴力

    A. Minimum Difficulty time limit per test 2 seconds memory limit per test 256 megabytes input standa ...

  3. Codeforces Round #584 D. Cow and Snacks

    链接: https://codeforces.com/contest/1209/problem/D 题意: The legendary Farmer John is throwing a huge p ...

  4. python爬虫学习(5) —— 扒一下codeforces题面

    上一次我们拿学校的URP做了个小小的demo.... 其实我们还可以把每个学生的证件照爬下来做成一个证件照校花校草评比 另外也可以写一个物理实验自动选课... 但是出于多种原因,,还是绕开这些敏感话题 ...

  5. 【Codeforces 738D】Sea Battle(贪心)

    http://codeforces.com/contest/738/problem/D Galya is playing one-dimensional Sea Battle on a 1 × n g ...

  6. 【Codeforces 738C】Road to Cinema

    http://codeforces.com/contest/738/problem/C Vasya is currently at a car rental service, and he wants ...

  7. 【Codeforces 738A】Interview with Oleg

    http://codeforces.com/contest/738/problem/A Polycarp has interviewed Oleg and has written the interv ...

  8. CodeForces - 662A Gambling Nim

    http://codeforces.com/problemset/problem/662/A 题目大意: 给定n(n <= 500000)张卡片,每张卡片的两个面都写有数字,每个面都有0.5的概 ...

  9. CodeForces - 274B Zero Tree

    http://codeforces.com/problemset/problem/274/B 题目大意: 给定你一颗树,每个点上有权值. 现在你每次取出这颗树的一颗子树(即点集和边集均是原图的子集的连 ...

  10. CodeForces - 261B Maxim and Restaurant

    http://codeforces.com/problemset/problem/261/B 题目大意:给定n个数a1-an(n<=50,ai<=50),随机打乱后,记Si=a1+a2+a ...

随机推荐

  1. 修改启动配置文件更改root密码

    第二种:修改启动配置文件 (1)进入救援模式 开机选择第一个系统内核,键入e (2)修改配置文件 将光标移动linux 开始的行,添加内核参数 rd.break 按ctrl-x启动 光标放在linux ...

  2. 小白终于解决了在学习Go中不知道Makefile是什么的难题

    如何在Go中使用Makefile 1.Makefile是什么 Makefile是一种构建工具,用于在项目中定义和执行一系列命令.它通常包含了一些规则和目标,用于编译.测试.运行和清理项目. 2.Mak ...

  3. 使用logrotate定期切割nginx日志

    前言 默认情况下,nginx的日志都会写到access.log文件中,访问流量大的话,日志文件很快就会膨胀到几十G,不方便分析处理,也占用硬盘空间.借助linux自带的logrotate工具可以很方便 ...

  4. 只要学会这些AI工具,一个人就是一家营销咨询公司

    随着AI工具的不断涌现,您只需掌握市面上热门的AI工具,便可独自开展营销咨询公司.通过一系列AI工具,您可以为企业提供全案服务,收获丰厚回报. 例如,在协助一家美妆初创公司出海时,我们运用一系列AI工 ...

  5. API接口的研发与应用

    ​ API(Application Programming Interface,应用程序编程接口)指的是为不同的软件应用程序提供编程接口的一组协议.规则以及工具的集合,以便它们能够互相交互,实现数据通 ...

  6. SqlServer表添加字段

    IF NOT EXISTS (SELECT * FROM syscolumns WHERE id=object_id('表名') AND name='字段名') ALTER TABLE 表名 ADD ...

  7. CodeForces 1343D Constant Palindrome Sum

    题意 多组样例 给一个长度为\(n\)(\(n\)一定为偶数)的数组\(a[]\),给一个正整数\(k\),保证数组内元素为小于等于\(k\)的正整数,你可以每次将数组的一个元素变为小于等于\(k\) ...

  8. 弹性数据库连接池探活策略调研(二)——Druid

    前言 在上一篇文章中,我们介绍了弹性数据库连接失效的背景,并探讨了HikariCP连接池探活策略的相关内容.在本文中,我们将会继续探讨另一个线上常用的连接池--Druid,并为您介绍如何在使用Drui ...

  9. Solution -「洛谷 P5072」「YunoOI 2015」盼君勿忘

    Description Link. 无修支持查询:查询一个区间 \([l,r]\) 中所有子序列分别去重后的和 \(\bmod\ p\) Solution 这是数据结构一百题的第50题(一半了哦)的纪 ...

  10. destoon运行流程二次开发必看

    <?php 代码首先包含common.inc.php文件 在common.inc.php文件中,首先定义常量. define('IN_DESTOON', true); define('IN_AD ...