热门标签 | 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;
}

推荐阅读
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ... [详细]
  • 本文介绍如何使用Objective-C结合dispatch库进行并发编程,以提高素数计数任务的效率。通过对比纯C代码与引入并发机制后的代码,展示dispatch库的强大功能。 ... [详细]
  • 火星商店问题:线段树分治与持久化Trie树的应用
    本题涉及编号为1至n的火星商店,每个商店有一个永久商品价值v。操作包括每天在指定商店增加一个新商品,以及查询某段时间内某些商店中所有商品(含永久商品)与给定密码值的最大异或结果。通过线段树分治和持久化Trie树来高效解决此问题。 ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • Splay Tree 区间操作优化
    本文详细介绍了使用Splay Tree进行区间操作的实现方法,包括插入、删除、修改、翻转和求和等操作。通过这些操作,可以高效地处理动态序列问题,并且代码实现具有一定的挑战性,有助于编程能力的提升。 ... [详细]
  • golang常用库:配置文件解析库/管理工具viper使用
    golang常用库:配置文件解析库管理工具-viper使用-一、viper简介viper配置管理解析库,是由大神SteveFrancia开发,他在google领导着golang的 ... [详细]
  • 本文详细探讨了KMP算法中next数组的构建及其应用,重点分析了未改良和改良后的next数组在字符串匹配中的作用。通过具体实例和代码实现,帮助读者更好地理解KMP算法的核心原理。 ... [详细]
  • 本文详细介绍了Java中org.neo4j.helpers.collection.Iterators.single()方法的功能、使用场景及代码示例,帮助开发者更好地理解和应用该方法。 ... [详细]
  • 本文详细介绍了 GWT 中 PopupPanel 类的 onKeyDownPreview 方法,提供了多个代码示例及应用场景,帮助开发者更好地理解和使用该方法。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 本文探讨了 Objective-C 中的一些重要语法特性,包括 goto 语句、块(block)的使用、访问修饰符以及属性管理等。通过实例代码和详细解释,帮助开发者更好地理解和应用这些特性。 ... [详细]
  • 本文详细介绍了 Apache Jena 库中的 Txn.executeWrite 方法,通过多个实际代码示例展示了其在不同场景下的应用,帮助开发者更好地理解和使用该方法。 ... [详细]
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社区 版权所有