codeforces 1029E Tree with Small Distances【思维+贪心】 【非原创】

题目:戳这里

学习博客:戳这里

题意:给一个树加最少的边,使得1到所有点的距离小于等于2.

解题思路:分析样例3可以看出,如果一个点到1的距离大于2,那么建立1到该点的父亲节点的边将比直接与该点建边更优。官方题解的做法是把所有与1距离大于2的点放到大顶堆里维护,每次取出最远的点,染色与该点父节点以及与父节点相接的所有点。也就是相当于与父节点建边,距离为1,与父节点的子节点的距离就为2了,于是把这些点弹出。从大佬博客中学到一个很妙的写法,是用dfs实现这个思路,具体看代码。

附ac代码:

 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 const int maxn = 2e5 + 10;
 4 int dis[maxn];
 5 vector<int>nu[maxn];
 6 int ans = 0;
 7 void dfs(int now, int pre, int cnt)
 8 {
 9
10     dis[now] = cnt;
11     int flag = 0;
12     for(int y : nu[now])
13     {
14        // printf("%d\n", y);
15         if(y == pre) continue;
16
17         dfs(y, now, cnt + 1);
18         if(dis[y] > 2)
19         {
20             flag = 1;
21             dis[now] = 1;
22             dis[pre] = 2;
23         }
24     }
25     ans += flag;
26
27 }
28 int main()
29 {
30     int n;
31     int u, v;
32     scanf("%d", &n);
33     for(int i = 1; i < n; ++i)
34     {
35         scanf("%d %d", &u, &v);
36         nu[u].push_back(v);
37         nu[v].push_back(u);
38     }
39     dfs(1, 1, 0);
40     printf("%d\n", ans);
41 }

原文地址:https://www.cnblogs.com/zmin/p/9595559.html

时间: 2024-08-28 23:49:18

codeforces 1029E Tree with Small Distances【思维+贪心】 【非原创】的相关文章

Codeforces Round #459 (Div. 2) C 思维,贪心 D 记忆化dp

Codeforces Round #459 (Div. 2) C. The Monster 题意:定义正确的括号串,是能够全部匹配的左右括号串. 给出一个字符串,有 (.). ? 三种字符, ? 可以当作 ( 可 ) . 问这个字符串有多少个子串是正确的括号串. tags:好考思维,想不到.. 预处理出每个字符向左向右最多可以匹配到哪里,再 O(n*n) 枚举所有区间,看是否符合条件. // C #include<bits/stdc++.h> using namespace std; #pra

CF 1029E Tree with Small Distances

小胖守皇宫! 又双叒叕水了一篇 1 #include<cstdio> 2 #include<cstring> 3 #include<algorithm> 4 using namespace std; 5 int n,m,cnt,ans; 6 int fa[200005]; 7 int dep[200005]; 8 int dp[200005][3]; 9 int head[200005]; 10 struct Edge{ 11 int fr; 12 int to; 13

Codeforces --- 982C Cut &#39;em all! DFS加贪心

题目链接: https://cn.vjudge.net/problem/1576783/origin 输入输出: ExamplesinputCopy42 44 13 1outputCopy1inputCopy31 21 3outputCopy-1inputCopy107 18 48 104 76 59 33 52 102 5outputCopy4inputCopy21 2outputCopy0NoteIn the first example you can remove the edge bet

Codeforces 348B:Apple Tree(DFS+LCM+思维)

http://codeforces.com/contest/348/problem/B 题意:给一棵树,每个叶子结点有w[i]个苹果,每个子树的苹果数量为该子树所有叶子结点苹果数量之和,要使得每个结点的各个子树苹果数量相等,求至少需要拿走的苹果数量. 思路:一开始以为只要使得所有子树之和相同就行了. 1 void dfs(int u, int fa) { 2 int num = 0, mi = INF; 3 for(int i = head[u]; ~i; i = edge[i].nxt) {

Codeforces 911F Tree Destruction(贪心 &amp;&amp; 树的直径)

题目链接  Tree Destructi 题意  给定一棵树,每次可以选定树上的两个叶子,并删去其中的一个.答案每次加上两个选定的叶子之间的距离. 求最后答案的最大值. 首先求出树的某一条直径,令其端点分别为L, R. 把L看成树的根,那么R一定是叶子结点. 对于那些非直径上的点,离他们最远的点肯定是L或R中的一个(可能也有其他的,但是L或R肯定已经最大了) 所以依次把这些非直径上的点删掉,删掉的时候在L和R中选择一个就行了. 最后把直径删掉即可. 时间复杂度$O(nlogn)$  (应该是可以

Codeforces 1093C (思维+贪心)

题面 传送门 题目大意: 有一个长n(n为偶数)的序列a 已知a满足 \(a_1≤a_2≤?≤a_n\) 给出一个长度为\(\frac{n}{2}\) 的序列b,定义\(b_i=a_i+a_{n-i+1}\) 求出序列a (输出任意一种答案即可) 分析 为了保证序列不下降,我们采用贪心的思想,先假设\(a_i=a_{i-1}\),这样给后面的数留有的余地更大 然后计算出\(a_{n-i+1}=b_i-a_i\),如果\(a_{n-i+1}>a_{n-i+1+1}\),即不满足不下降的条件,则进行

CodeForces - 1251E2 (思维+贪心)

题意 https://vjudge.net/problem/CodeForces-1251E2 一共有 n 个选民,你可以付出 pi? 的代价让第 i 个选民为你投票,或者,在为你投票的人数达到 mi? 时,他会主动为你投票而不用你付出任何代价. 问得到所有选民投票的最小代价. 思路 考虑贪心,对容易跟风的就跟风,对不容易跟风的就贿赂,所以对每个mi用vector插入相应的pi,然后从大到小遍历vector(不易跟风的要花钱),对于每一个mi,把对应的p插入到小根堆,小根堆里的人默认是跟风的,设

CodeForces - 1253C(思维+贪心)

题意 https://vjudge.net/problem/CodeForces-1253C n个糖果,一天最多吃m个糖果,每个糖果有个值a[i],第d天会变成d*a[i],问吃k(k=1~n)个糖果权值和的最小值分别是多少. 思路 先排序,再求一遍前缀和. 比如m=2,排序后:2 3 4 4 6 6 7,那么ans[1]=2,ans[2]=5:对于k=3,贪心的想法肯定是把大的两个第一天吃,小的第二天吃,ans[3]=11:对于k,肯定是把最大的m个第一天吃,剩下的可以通过ans[k-m]得到

Codeforces Round #629 (Div. 3) D. Carousel(思维/贪心?)

The round carousel consists of nn figures of animals. Figures are numbered from 11 to nn in order of the carousel moving. Thus, after the nn -th figure the figure with the number 11 follows. Each figure has its own type — the type of the animal corre