hdu 1011 Starship Troopers 树形背包dp
Starship Troopers
Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
To kill all the bugs is always easier than to capture their brains. A map is drawn for you, with all the rooms marked by the amount of bugs inside, and the possibility of containing a brain. The cavern's structure is like a tree in such a way that there is one unique path leading to each room from the entrance. To finish the battle as soon as possible, you do not want to wait for the troopers to clear a room before advancing to the next one, instead you have to leave some troopers at each room passed to fight all the bugs inside. The troopers never re-enter a room where they have visited before.
A starship trooper can fight against 20 bugs. Since you do not have enough troopers, you can only take some of the rooms and let the nerve gas do the rest of the job. At the mean time, you should maximize the possibility of capturing a brain. To simplify the problem, just maximize the sum of all the possibilities of containing brains for the taken rooms. Making such a plan is a difficult job. You need the help of a computer.
The last test case is followed by two -1's.
50 10
40 10
40 20
65 30
70 30
1 2
1 3
2 4
2 5
1 1
20 7
-1 -1
7
思路:蜜汁AC,bug为0也需要去人;
#pragma comment(linker, "/STACK:1024000000,1024000000")
#include<iostream>
#include<cstdio>
#include<cmath>
#include<string>
#include<queue>
#include<algorithm>
#include<stack>
#include<cstring>
#include<vector>
#include<list>
#include<bitset>
#include<set>
#include<map>
#include<time.h>
using namespace std;
#define LL long long
#define pb push_back
#define mkp make_pair
#define pi (4*atan(1.0))
#define eps 1e-8
#define bug(x) cout<<"bug"<<x<<endl;
const int N=1e2+,M=2e6+,inf=1e9+;
const LL INF=1e18+,mod=,MOD=; int dp[N][N],n,m;
int V[N],W[N];
vector<int>edge[N];
void dfs(int u,int fa,int m)
{
for(int i=V[u];i<=m;i++)
dp[u][i]=W[u];
for(int i=;i<edge[u].size();i++)
{
int v=edge[u][i];
if(v==fa)continue;
dfs(v,u,m-V[u]);
for(int j=m;j>=V[u];j--)
{
for(int k=;j-k>=V[u];k++)
if(dp[v][k])dp[u][j]=max(dp[u][j],dp[u][j-k]+dp[v][k]);
}
} } int main()
{
while(~scanf("%d%d",&n,&m))
{
if(n==-&&m==-)break;
memset(dp,,sizeof(dp));
for(int i=;i<=n;i++)
edge[i].clear();
for(int i=;i<=n;i++)
scanf("%d%d",&V[i],&W[i]),V[i]=(V[i]/)+(V[i]%?:);
for(int i=;i<n;i++)
{
int u,v;
scanf("%d%d",&u,&v);
edge[u].pb(v);
edge[v].pb(u);
}
if(!m)
{
printf("0\n");
continue;
}
dfs(,,m);
/*for(int i=1;i<=n;i++)
{
for(int j=0;j<=m;j++)
cout<<dp[i][j]<<" ";
cout<<endl;
}*/
printf("%d\n",dp[][m]);
}
return ;
}
hdu 1011 Starship Troopers 树形背包dp的更多相关文章
- HDU 1011 Starship Troopers 树形+背包dp
		
http://acm.hdu.edu.cn/showproblem.php?pid=1011 题意:每个节点有两个值bug和brain,当清扫该节点的所有bug时就得到brain值,只有当父节点被 ...
 - hdu 1011 Starship Troopers(树形背包)
		
Starship Troopers Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Other ...
 - hdu 1011 Starship Troopers(树形DP入门)
		
Starship Troopers Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Other ...
 - hdu 1011 Starship Troopers(树上背包)
		
Problem Description You, the leader of Starship Troopers, are sent to destroy a base of the bugs. Th ...
 - [HDU 1011] Starship Troopers (树形dp)
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1011 dp[u][i]为以u为根节点的,花了不超过i元钱能够得到的最大价值 因为题目里说要访问子节点必 ...
 - HDU  1011 Starship Troopers  树形DP 有坑点
		
本来是一道很水的树形DP题 设dp[i][j]表示,带着j个人去攻打以节点i为根的子树的最大收益 结果wa了一整晚 原因: 坑点1: 即使这个节点里面没有守卫,你如果想获得这个节点的收益,你还是必须派 ...
 - HDU 1011 Starship Troopers【树形DP/有依赖的01背包】
		
You, the leader of Starship Troopers, are sent to destroy a base of the bugs. The base is built unde ...
 - hdu 1011(Starship Troopers,树形dp)
		
Starship Troopers Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
 - hdu 1011  Starship Troopers   经典的树形DP ****
		
Starship Troopers Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Other ...
 
随机推荐
- 【linux应用】将一个大文件按行拆分成小文件
			
例如将一个BLM.txt文件分成前缀为 BLM_ 的1000个小文件,后缀为系数形式,且后缀为4位数字形式 先利用 wc -l BLM.txt #读出BLM.txt有多少行. 再利用 split 命令 ...
 - 输出链表中倒数第k个节点
			
题目描述 输入一个链表,输出该链表中倒数第k个结点. struct ListNode { int val; struct ListNode *next; ListNode(int x) : val(x ...
 - es6转es5在线工具
			
es6转es5在线工具:https://babeljs.io/repl/# 程序员常用在线工具:https://tool.lu/
 - Python 一些有趣的技巧,包括协程例
			
1. 路径操作 比起 os 模块的 path 方法,python3 标准库的 pathlib 模块的 Path 处理起路径更加的容易. ####获取当前文件路径 前提导入 os 和 pathlib 包 ...
 - oracle 11g enq: JI – contention等待事件
			
最近使用物化视图同步的环境在大量刷新的时候频繁出现enq: JI – contention等待事件,经查: JI enqueue is acquired in exclusive mode on th ...
 - 02: flask 使用举例
			
1.1 项目说明 https://github.com/rickyyangrui/Flask_web_demo1 1.项目文件结构 2.项目主文件 cssmin==0.2.0 Flask==0.1 ...
 - Oracle redo/undo 原理理解
			
一. 什么是redo(用于重做数据) redo也就是重做日志文件(redo log file),Oracle维护着两类重做日志文件:在线(online)重做日志文件和归档(archived)重做日志文 ...
 - oracle_sqlplus命令行乱码问题解决
			
在linux以及unix中,sqlplus的上下左右.回退无法使用,会出现乱码情况. 而rlwrap这个软件就是用来解决这个的. 首先下载rlwrap包:https://linux.linuxidc. ...
 - PO VO BO DTO POJO DAO之间的关系
			
J2EE开发中大量的专业缩略语很是让人迷惑,尤其是跟一些高手讨论问题的时候,三分钟就被人家满口的专业术语喷晕了,PO VO BO DTO POJO DAO,一大堆的就来了. PO:persistant ...
 - 浅析alsa声卡驱动snd_interval结构体openmin,openmax和integer含义
			
// openmin和openmax表示开集,如果2个全为1,那么就表示,range范围为(min,max)即2个开区间// openmin为1,openmax为0,range范围为(min,max] ...