热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

WeighttheTree(树形dp)

题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&#

题目Link
题目学习link1
题目学习link2
题目学习link3
%%% 受益匪浅!
--------------------------------

通过了解题意可知
当 n = 2 时 为一种特殊情况,特判一下(样例温和捏~
当 n > 2 时 当一个节点为good节点时,与其相连的节点一定为非good点
这样模型就显现出来了 类似于link2中所讲树的最小点覆盖问题
这里用 0 表示 该点不是good点 , 1 表示为good点
且只有 0-0 , 0- 1 两种情况,dp即可求出最大的 good 点个数
由于还要求最小的节点权值和,开个结构体用dp数组一起求
状态转移见代码

/**@author:bzdhxs*@date:2022/03/15*@URL:
*/

#include
#include
#include
#include
#include
#include
#include
#include
#include
using namespace std;
template <typename T>
inline void read(T &s){s &#61; 0;T w &#61; 1, ch &#61; getchar();while (!isdigit(ch)) { if (ch &#61;&#61; &#39;-&#39;) w &#61; -1; ch &#61; getchar(); }while (isdigit(ch)) { s &#61; (s << 1) &#43; (s << 3) &#43; (ch ^48); ch &#61; getchar();} s *&#61; w;}
template <typename T>
inline void write(T s){if (s < 0) putchar(&#39;-&#39;), s &#61; -s;if (s > 9) write(s / 10);putchar(s % 10 &#43; &#39;0&#39;);}
#define int long long
#define _orz ios::sync_with_stdio(false),cin.tie(0)
#define mem(str,num) memset(str,num,sizeof(str))
#define forr(i,a,b) for(int i &#61; a; i <&#61; b;i&#43;&#43;)
#define forn(i,n) for(int i &#61; 0; i
#define dbg() cout <<"0k!"<
typedef long long ll;
int pri[16] &#61; {2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53};
const int inf &#61; 0x3f3f3f3f;
const int INF &#61; ~0ULL;
const int N &#61; 1e6&#43;10;int n;
vector<int> g[200005];
struct node{int g,s; // g 记录好点个数 s 记录权值和//用来取较优的点bool operator>(const node&t)const{if(g !&#61; t.g) return g > t.g; //优先good点个数&#xff0c;相同取权值小的return s < t.s;}
}dp[200005][2];//树形dp
void dfs1(int u,int fa){dp[u][0].s &#61; 1;// 非good点权值为1&#xff0c;最小dp[u][1].s &#61; g[u].size();// 作为good点权值为直接连边的个数dp[u][1].g &#61; 1;// 为good点故为1for(auto v:g[u]){if(v &#61;&#61; fa) continue;dfs1(v,u);// u作为good点dp[u][1].g &#43;&#61; dp[v][0].g; // 直接连边的均为非good点取dp[v][0]dp[u][1].s &#43;&#61; dp[v][0].s;// 当 u为非good点的时候&#xff0c;v可以为good 也可以为非good 取最优&#xff1b;int best &#61; (dp[v][0] > dp[v][1])?0:1;dp[u][0].g &#43;&#61; dp[v][best].g;dp[u][0].s &#43;&#61; dp[v][best].s;}
}int w[200005];// 再次遍历更新点的权值
void dfs2(int u,int fa,int bes){// good 就取相连点个数 否则取1&#xff1b;w[u] &#61; (bes)?g[u].size():1;for(auto v:g[u]){if(v &#61;&#61; fa) continue;// 当前节点为good那么相邻节点就为非goodif(bes) dfs2(v,u,0);else{int best &#61; (dp[v][0] > dp[v][1])?0:1;dfs2(v,u,best);}}
}
signed main()
{cin >> n;forr(i,1,n-1){int l,r;cin >> l >> r;g[l].push_back(r);g[r].push_back(l);}//特判2if(n &#61;&#61; 2){cout << 2 <<" " << 2 << endl;cout << 1 <<" "<< 1 << endl;return 0;}dfs1(1,0);int best &#61; (dp[1][0] > dp[1][1])?0:1;//求每个点的权值dfs2(1,0,best);// 输出1节点最优情况cout << dp[1][best].g <<" "<<dp[1][best].s<<endl;forr(i,1,n) cout << w[i] <<" \n"[i&#61;&#61;n];return 0;
}

推荐阅读
  • Codeforces Round #566 (Div. 2) A~F个人题解
    Dashboard-CodeforcesRound#566(Div.2)-CodeforcesA.FillingShapes题意:给你一个的表格,你 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文详细介绍了 Apache Jena 库中的 Txn.executeWrite 方法,通过多个实际代码示例展示了其在不同场景下的应用,帮助开发者更好地理解和使用该方法。 ... [详细]
  • 不确定性|放入_华为机试题 HJ9提取不重复的整数
    不确定性|放入_华为机试题 HJ9提取不重复的整数 ... [详细]
  • 本文介绍如何使用Objective-C结合dispatch库进行并发编程,以提高素数计数任务的效率。通过对比纯C代码与引入并发机制后的代码,展示dispatch库的强大功能。 ... [详细]
  • C++实现经典排序算法
    本文详细介绍了七种经典的排序算法及其性能分析。每种算法的平均、最坏和最好情况的时间复杂度、辅助空间需求以及稳定性都被列出,帮助读者全面了解这些排序方法的特点。 ... [详细]
  • 本文探讨了 Objective-C 中的一些重要语法特性,包括 goto 语句、块(block)的使用、访问修饰符以及属性管理等。通过实例代码和详细解释,帮助开发者更好地理解和应用这些特性。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 本文探讨了 C++ 中普通数组和标准库类型 vector 的初始化方法。普通数组具有固定长度,而 vector 是一种可扩展的容器,允许动态调整大小。文章详细介绍了不同初始化方式及其应用场景,并提供了代码示例以加深理解。 ... [详细]
  • 文件描述符、文件句柄与打开文件之间的关联解析
    本文详细探讨了文件描述符、文件句柄和打开文件之间的关系,通过具体示例解释了它们在操作系统中的作用及其相互影响。 ... [详细]
  • 本文详细探讨了VxWorks操作系统中双向链表和环形缓冲区的实现原理及使用方法,通过具体示例代码加深理解。 ... [详细]
  • 本文提供了使用Java实现Bellman-Ford算法解决POJ 3259问题的代码示例,详细解释了如何通过该算法检测负权环来判断时间旅行的可能性。 ... [详细]
  • 本题旨在通过给定的评级信息,利用拓扑排序和并查集算法来确定全球 Tetris 高手排行榜。题目要求判断是否可以根据提供的信息生成一个明确的排名表,或者是否存在冲突或信息不足的情况。 ... [详细]
  • 本文深入探讨了POJ2762问题,旨在通过强连通分量缩点和单向连通性的判断方法,解决有向图中任意两点之间的可达性问题。文章详细介绍了算法原理、实现步骤,并附带完整的代码示例。 ... [详细]
author-avatar
俊维肇民74
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有