hdu1561 树形dp,依赖背包
多重背包是某个物品可以选择多次,要把对物品数的枚举放在对w枚举外面
分组背包是某组的物品只能选一个,要把对每组物品的枚举放在对w枚举内侧
依赖背包是多层的分组背包,利用树形结构建立依赖关系,每个结点都可以看做分组背包来做
/*
dp[i][j]表示以点i为根,取j个点的状态
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#include<vector>
using namespace std;
#define maxn 300
vector<int>G[maxn];
int n,m,dp[maxn][maxn],v[maxn];
void dfs(int fa){
for(int i=;i<G[fa].size();i++){
int ch=G[fa][i];
if(G[ch].size()>)dfs(ch);
}
for(int i=;i<G[fa].size();i++){//这就是一个分组背包
int ch=G[fa][i];
for(int j=m;j>=;j--)
for(int k=;k<=j;k++)
dp[fa][j]=max(dp[fa][j],dp[fa][k]+dp[ch][j-k]);
}
}
int main(){
while(scanf("%d%d",&n,&m),n){
int a,b;
m++;//多加一个虚点
memset(dp,,sizeof dp);
for(int i=;i<=n;i++)G[i].clear(); for(int i=;i<=n;i++){
scanf("%d%d",&a,&b);
v[i]=b;G[a].push_back(i);
for(int j=;j<=m;j++)
dp[i][j]=b;
}
dfs();
printf("%d\n",dp[][m]); }
}
hdu1561 树形dp,依赖背包的更多相关文章
- HDU4003Find Metal Mineral[树形DP 分组背包]
		
Find Metal Mineral Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65768/65768 K (Java/Other ...
 - 【P2015】二叉苹果树 (树形DP分组背包)
		
题目描述 有一棵苹果树,如果树枝有分叉,一定是分2叉(就是说没有只有1个儿子的结点) 这棵树共有N个结点(叶子点或者树枝分叉点),编号为1-N,树根编号一定是1. 现在这颗树枝条太多了,需要剪枝.但是 ...
 - poj2486 Apple Tree (树形dp+分组背包)
		
题目链接:https://vjudge.net/problem/POJ-2486 题意:一棵点权树,起点在1,求最多经过m条边的最大点权和. 思路: 树形dp经典题.用3维状态,dp[u][j][0/ ...
 - hdu1561 The more, The Better 树形DP+分组背包
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1561 思路: 典型的树形背包题目: 定义dp[i][j]表示以i为根节点,攻打j个城堡的获得的财宝的最 ...
 - HDU1561:The more, The Better(树形DP+01背包)
		
Problem Description ACboy很喜欢玩一种战略游戏,在一个地图上,有N座城堡,每座城堡都有一定的宝物,在每次游戏中ACboy允许攻克M个城堡并获得里面的宝物.但由于地理位置原因,有 ...
 - hiho1055/hdu1561 - 树形dp转换成背包
		
题目链接 输入:一棵树,每个节点一个权值. 输出:包括1号节点在内的m个节点组成的连通分量的权值和的最大值 hdu1561和hiho1055一样,只是变换了下说法 /***************** ...
 - hdu1561 树形dp + 背包
		
#include<cstdio> #include<cstring> #include<iostream> #define INF 999999999 using ...
 - HDU-1561 The more, The Better (树形DP+分组背包)
		
题目大意:给出一片森林,总共有n个点,并且都有权值.从中选出m个,使权值和最大.其中,选某个节点之前必须先选其父节点. 题目分析:给所有的树都加一个共同的权值为0的根节点,使森林变成一棵树.定义状态d ...
 - POJ 1947Rebuilding Roads(树形DP + 01背包)
		
题目链接 题意:给出一个树形结构,求P个节点的子树最少要去掉几条边 分析:DP[root][j] 表示 以第 root 个为根节点, 包含j 个节点需要去掉几条边.那么对于 root 这个根节点来说, ...
 
随机推荐
- ADO.NET入门教程(五) 细说数据库连接池
			
摘要 今天我要讲的是数据库连接池.说实话,我表示鸭梨很大.因为相比其他章节来说,连接池相对来说难理解一点.我要用最通俗的语句给大家讲明白,讲透彻却也不是一件很容易的事.但是,连接池又是非常重要的知识点 ...
 - Mysql跨表更新
			
Mysql跨表更新一直是大家所关心的话题,本文介绍mysql多表 update在实践中几种不同的写法,需要的朋友可以参考下 假定我们有两张表,一张表为Product表存放产品信息,其中有产品价格列Pr ...
 - StringUtils中isEmpty 和isBlank的区别
			
StringUtils在commons-lang-2.2.jar包中:org.apache.commons.lang.StringUtils ; StringUtils方法的操作对象是java.lan ...
 - 离线方式部署Ambari2.6.0.0
			
Hadoop生态圈-离线方式部署Ambari2.6.0.0 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 我现在所在的公司用的是CDH管理Hadoop集群,前端时间去面试时发现很多 ...
 - JAVA-大白话探索JVM-类加载过程(二)
			
首先我们知道JVM是什么以及类加载器的作用 不清楚的可以看看JAVA-大白话探索JVM-类加载器(一) 现在我们来摸索下类的加载过程 首先,我们将类加载过程分为三步走 装载 链接 初始化 其中 链接 ...
 - Kruskal算法:最小生成树
			
//Kruskal算法按照边的权值从小到大查看一遍,如果不产生圈(重边等也算在内),就把当前这条表加入到生成树中. //如果判断是否产生圈.假设现在要把连接顶点u和顶点v的边e加入生成树中.如果加入之 ...
 - 008、Docker 组件如何协作(2018-12-25 周二)
			
参考https://www.cnblogs.com/CloudMan6/p/6774519.html 以httpd为例,介绍Docker组件间如何协作 root@docker-lab:~# d ...
 - Unity3d跨平台原理
			
知乎的一个提问:unity3d跨平台原理 一些资料: IL IL是.NET框架中中间语言(Intermediate Language)的缩写.使用.NET框架提供的编译器可以直接将源程序编译为.exe ...
 - OptionParser命令参数介绍及使用
			
使用optionParse解析命令行参数分以下几个步骤: 创建parser实例 使用add_option添加我们要处理的命令行参数 得到解析sys.argv后的options对象,查看用户的输入 代码 ...
 - IO流总结笔记三
			
 字节流: 抽象基类:InputStream, OutputStream. 字节流可以操作任何数据.注意:字符流使用的数组是字符数组.Char [] chs 字节流使用的数组是字节数组.Byte [ ...