196、【动态规划】AcWing —— 285. 没有上司的舞会(C++版本)
创始人
2024-06-01 10:48:09
0

题目描述

在这里插入图片描述
在这里插入图片描述
原题链接:285. 没有上司的舞会

解题思路

题目是要构造一个树形关系,在选择时,有直接上下级关系的不能选,但是对于有间接上下级关系的和非上下级关系的都可以选。

  • 动态规划五步曲:

(1)dp[i][2]含义: dp[i][0]:以i为根节点并且不选节点i时,具有的最大快乐数。dp[i][1]:以i为根节点并且选节点i时,具有的最大快乐数。

(2)递推公式: dp[i][1]=dp[i][1]+dp[j][0]dp[i][1] = dp[i][1] + dp[j][0]dp[i][1]=dp[i][1]+dp[j][0](其中j为i的孩子节点),意为选择当前节点的情况下加上不选择孩子节点的情况;dp[i][0]=max(dp[j][0],dp[j][1])dp[i][0] = max(dp[j][0], dp[j][1])dp[i][0]=max(dp[j][0],dp[j][1]),意为在不选择i节点的情况下,选择孩子节点和不选择孩子节点时候找到一个最大值。

(3)dp数组初始化: dp[i][1] = happy[i],当选择孩子节点时,初始时候为自身的快乐数值。

(4)遍历顺序: 后序遍历,从左到右,从下到上,将低层结果传递给上一层。

(5)举例: (省略)

#include 
#include 
#include using namespace std;const int N = 6010;
int n;
int happy[N];
int dp[N][2];
int e[N], ne[N], h[N], idx;     //邻接表。e[i]:存放新节点,ne[i]:新节点的next,h[i]:头指针,idx:指向全局的下标
bool has_father[N];             // 判断下表i对应的节点是否有父节点。void add(int a, int b) {        // 头插法,将b插入到a中,a为父节点,b为子节点e[idx] = b, ne[idx] = h[a], h[a] = idx++;       // 构建节点b,让b的next指向a的next,让a的next指向b,更新idx。
}void dfs(int u) {dp[u][1] = happy[u];                        // 初始化构建快乐数for(int i = h[u]; i != -1; i = ne[i]) {     // 从树的根节点开始,遍历它下一层的所有孩子节点int j = e[i];                           // 找到节点u的孩子节点dfs(j);                                 // 采用后序遍历,先向下回溯遍历,再计算结果,将结果结果传递给上一层// 注意:这里加的时候要加到最初的起始节点处dp[u][0] += max(dp[j][1], dp[j][0]);    // 第一种情况:不选u,则可能最大值为选择孩子或不选孩子dp[u][1] += dp[j][0];                   // 第二种情况:选择当前节点,则就不选孩子节点(注意此时可选孙子节点)。}
}int main() {// 1、输入数据,构建关系树cin >> n;for(int i = 1; i <= n; i++)         cin >> happy[i];memset(h, -1, sizeof h);for(int i = 0; i < n - 1; i++) {int b, a;cin >> b >> a;              // b为下级,a为直接上司has_father[b] = true;       // b存在父节点add(a, b);                  // 构建a为b的父节点关系结构}// 2、寻找根节点int root = 1;while(has_father[root] == true)     root++;// 3、找到最大快乐数dfs(root);cout << max(dp[root][0], dp[root][1]) << endl;return 0;
}

参考视频:9.80 树形DP 没有上司的舞会——信息学竞赛培训课程

相关内容

热门资讯

虞书欣谈成名的代价令人心疼,如... 虞书欣谈成名的代价令人心疼,如今她在圈内的前景如何?虞书欣在圈内前景是很不错的,大家都很喜欢她,也有...
最有效的减肥食谱 最有效的减肥食谱谁有最有效的减肥食谱呢?麻烦给一个吧?急求最有效的减肥食谱,听说有一个什么汤的可以很...
关晓彤鹿晗被曝月底会分手,你对... 关晓彤鹿晗被曝月底会分手,你对于他们两个的爱情有什么看法?当初我也觉得他们俩的感情肯定不会长久的,但...
她曾在家中喂猪,却被张艺谋相中... 她曾在家中喂猪,却被张艺谋相中一夜成名,魏敏芝如今过得怎样?魏敏芝过得非常不错啊,而且当地的头衔也是...
电影《中邪》主要讲了什么? 电影《中邪》主要讲了什么?中邪的剧情简介 · · · · · ·大学生丁鑫和刘梦为拍摄农村风俗纪录片...
可以在营业厅查到短信的内容吗? 可以在营业厅查到短信的内容吗?查自己的短信==如果你是本人应该可以…不是本人是不可以的那是别人的隐私...
春日时雨时晴,杏花开时,小雨落... 春日时雨时晴,杏花开时,小雨落在身上,衣服欲湿未湿;杨柳风最柔,吹到脸上也下觉其寒。是什么诗句沾衣欲...
低学历的女人真的不能娶吗? 低学历的女人真的不能娶吗?我觉得不是的,娶妻子还是主要看对方的品性如何,而不是在意对方的学历。不一定...
电影配音问题 懂的进来 不是很... 电影配音问题 懂的进来 不是很难我想知道一个问题 比如说 一个电影 演员是 X 那他的说...可以是...
关于大蒜的谜语有哪些 关于大蒜的谜语有哪些有关蒜的谜语有:两二小,头长草 (打字一)谜底:蒜弟兄七八个,围着柱子坐,只要一...
怎么夸老师漂亮 怎么夸老师漂亮老师您长得太有气质了,非常出众,我身为一个女孩子都快要把持不住了。就直接一点说:老师你...
一般怎么钢琴即兴伴奏,一拿到简... 一般怎么钢琴即兴伴奏,一拿到简谱就能伴奏的和弦 天空之城简易般的可一参考 摸摸就出来的 弹一个音 ...
我对异地女友说,异地太苦了我真... 我对异地女友说,异地太苦了我真心问你,你和我一起内心快乐吗?她说,不管日子再苦,有你就是甜的?你一个...
为什么叫镇江 为什么叫镇江为什么叫镇江意义为"Garrison of the Yangtze River"
在足球历史上,阿贾克斯都获得过... 在足球历史上,阿贾克斯都获得过多少次欧冠?一共应该是获得过4次冠军,而且他真的是特别厉害,很少有人可...
时间简史是谁写的? 时间简史是谁写的?史蒂芬·威廉·霍金
我爱她,但她爱他。 我爱她,但她爱他。如果换了我是你!我会一直的爱着她!她爱着他,你又爱着他!她知道爱一个不爱自己人的资...
歌词:我是你的月亮,是你夜里的... 歌词:我是你的月亮,是你夜里的光芒。叫月光曲,嘿嘿
枪神纪里面的英文歌曲叫什么? 枪神纪里面的英文歌曲叫什么?枪神纪里面的英文歌曲叫什么?一首是男的一首是女的,女的那首好像有一句是,...
中外小朋友 大家手拉手 来自五... 中外小朋友 大家手拉手 来自五大洲 是什么歌名?中外小朋友 大家手拉手 来自五大洲 是什么歌名?《庆...