Codeforces 1566E Buds Re-hanging
原题链接 Codeforces Global Round 16 E. Buds Re-hanging
首先想到,如果我们把一个\(buds\)挂到一个叶子上,那么会使得叶子总数减\(1\)。
还有就是如果我们可以把这个树搞成一条链,那么总叶子数一定是最少的,就是让树“越瘦越好”。
如果原来一个\(buds\)挂在一个没有其他孩子的结点上,我们拿走这个\(buds\)之后会使得总叶子数加\(1\),我们称这个结点为 \(\alpha\),如果一个buds挂在一个有其他孩子的节点上,那么拿走这个\(buds\)总叶子数不会改变,我们称这个结点为\(\beta\)。
我们考虑把所有的\(buds\)全挂在\(root\)上,那么这样做会使结果变坏吗?当然不会
- 如果一个\(buds\)挂在一个\(\beta\)结点上,那么拿走后总叶子数不变。
- 如果一个\(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的更多相关文章
- CodeForces 构造题专项解题报告
CodeForces 构造题专项解题报告 \(\newcommand \m \mathbf\)\(\newcommand \oper \operatorname\) \(\text{By DaiRui ...
- 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 ...
- Codeforces Round #584 D. Cow and Snacks
链接: https://codeforces.com/contest/1209/problem/D 题意: The legendary Farmer John is throwing a huge p ...
- python爬虫学习(5) —— 扒一下codeforces题面
上一次我们拿学校的URP做了个小小的demo.... 其实我们还可以把每个学生的证件照爬下来做成一个证件照校花校草评比 另外也可以写一个物理实验自动选课... 但是出于多种原因,,还是绕开这些敏感话题 ...
- 【Codeforces 738D】Sea Battle(贪心)
http://codeforces.com/contest/738/problem/D Galya is playing one-dimensional Sea Battle on a 1 × n g ...
- 【Codeforces 738C】Road to Cinema
http://codeforces.com/contest/738/problem/C Vasya is currently at a car rental service, and he wants ...
- 【Codeforces 738A】Interview with Oleg
http://codeforces.com/contest/738/problem/A Polycarp has interviewed Oleg and has written the interv ...
- CodeForces - 662A Gambling Nim
http://codeforces.com/problemset/problem/662/A 题目大意: 给定n(n <= 500000)张卡片,每张卡片的两个面都写有数字,每个面都有0.5的概 ...
- CodeForces - 274B Zero Tree
http://codeforces.com/problemset/problem/274/B 题目大意: 给定你一颗树,每个点上有权值. 现在你每次取出这颗树的一颗子树(即点集和边集均是原图的子集的连 ...
- CodeForces - 261B Maxim and Restaurant
http://codeforces.com/problemset/problem/261/B 题目大意:给定n个数a1-an(n<=50,ai<=50),随机打乱后,记Si=a1+a2+a ...
随机推荐
- EasyExcel中使用表头模板示例
解决方案 在EasyExcel的官方示例中,使用模板导出Excel,其结果仍然还会重新打印表头.不满足使用表头模板的需求.在参考源码后,找到如下解决方案. String templateFileNam ...
- spring-mvc系列:简介和基本使用
目录 一.简介 1.什么是MVC 2.什么是SpringMVC 3.SpringMVC的特点 二.基本使用 1.开发环境 2.创建maven工程 3.配置web.xml 4.创建SpringMVC的配 ...
- vue实现文本复制
一. 下载插件 npm install --save vue-clipboard2 二. main.js import VueClipBoard from 'vue-clipboard2' Vue.u ...
- Gin中间件开发
Gin是一个用Go语言编写的Web框架,它提供了一种简单的方式来创建HTTP路由和处理HTTP请求.中间件是Gin框架中的一个重要概念,它可以用来处理HTTP请求和响应,或者在处理请求之前和之后执行一 ...
- SpringBoot 笔记
SpringBoot 笔记 一.Spring Boot 入门 1.Spring Boot 简介 2.微服务 2014,martin fowler 微服务:架构风格(服务微化) 一个应用应该是一组小型服 ...
- 《Kali渗透基础》06. 主动信息收集(三)
@ 目录 1:服务识别 1.1:NetCat 1.2:Socket 1.3:dmitry 1.4:nmap 2:操作系统识别 2.1:Scapy 2.2:nmap 2.3:p0f 3:SNMP 扫描 ...
- C++算法之旅、04 基础篇 | 第一章
常用代码模板1--基础算法 - AcWing ios::sync_with_stdio(false) 提高 cin 读取速度,副作用是不能使用 scanf 数据输入规模大于一百万建议用scanf 快速 ...
- .NET应用多语言-葡萄牙语软件,如何处理本地化,特别是数字的转换和计算
在葡萄牙语软件中,数字本地化通常涉及小数点和千位分隔符的使用.在葡萄牙语中,小数点用","表示,而不是英语中使用的".".千位分隔符通常是一个空格或一个点. 例 ...
- iperf 工具使用总结
转载请注明出处: iperf是一个用于测量网络带宽的工具,可以通过客户端和服务器之间的数据传输来评估网络性能.下面详细介绍iperf的使用方法.常用命令和参数以及注意事项,并提供一些示例说明.在ipe ...
- Ds100p -「数据结构百题」61~70
61.P5355 [Ynoi2017]由乃的玉米田 由乃在自己的农田边散步,她突然发现田里的一排玉米非常的不美. 这排玉米一共有 \(N\) 株,它们的高度参差不齐. 由乃认为玉米田不美,所以她决定出 ...