关于树形DP几道入门题目

今天恶补树形DP,感觉海星。

其实挺简单的。

介绍几道例题,我会的。

1.洛谷P1352 没有上司的舞会

我的一篇题解

我们可以考虑每一个节点都是有两种情况。

一个是被邀请;另一个是不会被邀请。

前者后果就是子节点不可以被选择;

后者结果就是子节点可以被选择。

于是关系明确,状态转移方程为:

dp[root][0] += std::max(dp[son[root][i]][0],dp[son[root][i]][1]);

dp[root][1] += dp[son[root][i]][0];

海星。

son[root][i]是当前节点的儿子。

初始化要记得是每一个点的快乐指数。

#include <cstdio>
#include <iostream>
#include <cmath>
#include <cstring>
#include <algorithm>
#include <queue>
#include <stack>
#include <vector>
#define Max 6050
#define re register
std::vector<int>son[Max];
int n,root,dp[Max][2],fa[Max];
void dfs(int root) {
for(re int i = 0 ; i < son[root].size() ; ++ i)
dfs(son[root][i]);
for(re int i = 0 ; i < son[root].size() ; ++ i) {
dp[root][0] += std::max(dp[son[root][i]][0],dp[son[root][i]][1]);
dp[root][1] += dp[son[root][i]][0];
}
}
void init() {
scanf("%d",&n);int u,v;memset(fa,-1,sizeof fa);
for(re int i = 1 ; i <= n ; ++ i) scanf("%d",&dp[i][1]);
for(re int i = 1 ; i < n ; ++ i)
scanf("%d%d",&u,&v),fa[u]=v,son[v].push_back(u);
scanf("%d%d",&u,&v);
}
inline void print(int root) {printf("%d",std::max(dp[root][0],dp[root][1]));}
void work() {
int root=1;
while(fa[root] != -1) root = fa[root];
dfs(root);
print(root);
}
int main() {
init();
work();
return 0;
}

2.poj1463 Strategic game

我们考虑每一个节点有两种情况。

一个是被选择;另一个是不被选择。

前者的结果是他的子节点可以被选择,也可以不被选择;

后者的结果是他的子节点必须备选择。

所以状态转移方程出来了:

dp[root][0] += std::max(dp[son[root][i]][0],dp[son[root][i]][1]);

dp[root][1] += dp[son[root][i]][0];

#include <cstdio>
#include <iostream>
#include <cmath>
#include <cstring>
#include <algorithm>
#include <queue>
#include <stack>
#include <vector>
#define Max 1550
#define re register
int n,dp[Max][2],fa[Max];
std::vector<int>son[Max];
void dfs(int root) {
for(re int i = 0 ; i < son[root].size() ; ++ i)
dfs(son[root][i]);
for(re int i = 0 ; i < son[root].size() ; ++ i) {
dp[root][0] += dp[son[root][i]][1];
dp[root][1] += std::min(dp[son[root][i]][0],dp[son[root][i]][1]);
}
}
void print(int root) {printf("%d\n",std::min(dp[root][0],dp[root][1]));}
void work() {
int root=0;
while(fa[root] != -1) root = fa[root];
dfs(root);
print(root);
}
void init() {
int k,x,y;char ch;
while(scanf("%d",&n) != EOF) {
for(re int i = 0 ; i < n ; ++ i)
fa[i] = -1,dp[i][0] = 0,dp[i][1] = 1;
for(re int p = 1 ; p <= n ; ++ p) {
scanf("%d",&k);std::cin >> ch;
std::cin >> ch;scanf("%d",&y);
std::cin >> ch;son[k].clear();
for(re int i = 1 ; i <= y ; ++ i)
scanf("%d",&x),fa[x]=k,son[k].push_back(x);
}
work();
}
}
int main() {
init();
return 0;
}

树形DP入门题目推荐以及解析的更多相关文章

  1. POJ:2342-Anniversary party(树形dp入门题目)

    传送门:http://poj.org/problem?id=2342 Anniversary party Time Limit: 1000MS Memory Limit: 65536K Descrip ...

  2. 树形DP入门详解+题目推荐

    树形DP.这是个什么东西?为什么叫这个名字?跟其他DP有什么区别? 相信很多初学者在刚刚接触一种新思想的时候都会有这种问题. 没错,树形DP准确的说是一种DP的思想,将DP建立在树状结构的基础上. 既 ...

  3. 树形dp 入门

    今天学了树形dp,发现树形dp就是入门难一些,于是好心的我便立志要发一篇树形dp入门的博客了. 树形dp的概念什么的,相信大家都已经明白,这里就不再多说.直接上例题. 一.常规树形DP P1352 没 ...

  4. POJ 2342 树形DP入门题

    有一个大学的庆典晚会,想邀请一些在大学任职的人来參加,每一个人有自己的搞笑值,可是如今遇到一个问题就是假设两个人之间有直接的上下级关系,那么他们中仅仅能有一个来參加,求请来一部分人之后,搞笑值的最大是 ...

  5. [poj2342]Anniversary party树形dp入门

    题意:选出不含直接上下司关系的最大价值. 解题关键:树形dp入门题,注意怎么找出根节点,运用了并查集的思想. 转移方程:dp[i][1]+=dp[j][0];/i是j的子树 dp[i][0]+=max ...

  6. LuoGu-P1122 最大子树和+树形dp入门

    传送门 题意:在一个树上,每个加点都有一个值,求最大的子树和. 思路:据说是树形dp入门. 用dfs,跑一边,回溯的时候求和,若和为负数,则减掉,下次不记录这个节点. #include <ios ...

  7. (树形DP入门题)Anniversary party(没有上司的舞会) HDU - 1520

    题意: 有个公司要举行一场晚会.为了让到会的每个人不受他的直接上司约束而能玩得开心,公司领导决定:如果邀请了某个人,那么一定不会再邀请他的直接的上司,但该人的上司的上司,上司的上司的上司等都可以邀请. ...

  8. hdu_Anniversary party_(树形DP入门题)

    题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=1520 题意:有N个人,N-1个人有自己的上司,每个人有一个快乐值,如果这个人参加了聚会,那么这个人的直 ...

  9. 树形DP入门学习

    这里是学习韦神的6道入门树形dp进行入门,本来应放在day12&&13里,但感觉这个应该单独放出来好点. 这里大部分题目都是参考的韦神的思想. A - Anniversary part ...

随机推荐

  1. Bagging 和RF的区别

    跑训练无聊看了看别人的面经,发现自己一时半会答不上来,整理一下. 一.Bagging介绍 先看一个Bagging的一个概念图(图来自https://www.cnblogs.com/nickchen12 ...

  2. phpstorm 2016.3.2 的最新破解方法

    v2.0 最新的方式 第一:下载PHPStorm20173.2:(下载链接:windows) 第二:直接用浏览器打开 http://idea.lanyus.com/ ,点击页面中的“获得注册码”,然后 ...

  3. 【WPF】1、 基本控件的简介

    WPF一直都是断断续续的使用.偶尔用到一下.但是每次间隔比较长,需要重新学习,就写了这篇日志.以后有问题,看这个就可以了解各大概,然后针对细节再另外想办法. 微软的东西真心好,如果什么都不懂,可以直接 ...

  4. Java的Stream流式操作

    前言 最近在实习,在公司看到前辈的一些代码,发现有很多值得我学习的地方,其中有一部分就是对集合使用Stream流式操作,觉得很优美且方便.所以学习一下Stream流,在这里记录一下. Stream是什 ...

  5. Calendar类set方法中的坑

    最近写了一个支付宝微信对账报表,发现系统金额比支付宝微信的少好多,左查右查发现是追缴金额没统计到,再一查发现月结束日期为2019-09-31,9月咋会有31,为啥呢就追缴金额不行呢,因为其他类型用TI ...

  6. Serverless

    一.介绍 是指依赖于第三方应用程序或服务来管理服务器端逻辑的应用程序. 此类应用程序是基于云的数据库(如Google Firebase)或身份验证服务. 无服务器也意味着开发为事件触发的代码,并且在无 ...

  7. requestAnimationFrame ---- 请求动画帧。

    window.requestAnimationFrame() 告诉浏览器——你希望执行一个动画,并且要求浏览器在下次重绘之前调用指定的回调函数更新动画.该方法需要传入一个回调函数作为参数,该回调函数会 ...

  8. Django 连接 MySQL 数据库及常见报错解决

    目录 Django 连接 MySQL数据库及常见报错解决 终端或者数据库管理工具连接 MySQL ,并新建项目所需数据库 安装访问 MySQL 的 Python 模块 Django 相关配置 可能会遇 ...

  9. 前端工程师拿到全新的 Mac 需要做哪些准备

    最近苹果退出了新款 Mac,用了3年15款Pro之后,终于盼到18款的降价,于是含泪更新换代 但是每次换电脑,重装环境的好多东西记不清,于是记个笔记 一.终端 安装 zsh sh -c "$ ...

  10. AI面试-算法结构基础

    其实目前国内几乎只要是技术岗,面试中都100%会问算法和数据结构. 这两者能快速体现候选人真实的水平,比如代码量,代码的质量,性能,思维是否有逻辑,是否灵活. 算法结果概述 1.前言 1.应用范围:机 ...