题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=4616

这道题目数据可能比较弱,搜索都可以AC,但是不敢写,哎……

搜索AC代码:

#include <iostream>
#include <cstdio>
#include <cstring>
#include <string>
#include <cstdlib>
#include <cmath>
#include <vector>
#include <list>
#include <deque>
#include <queue>
#include <iterator>
#include <stack>
#include <map>
#include <set>
#include <algorithm>
#include <cctype>
#include <ctime>
#pragma comment(linker, "/STACK:16777216")
using namespace std; typedef __int64 LL;
const int N=50005;
const int M=55555555;
const int INF=0x3f3f3f3f;
const double PI=acos(-1.0); vector<int>q[N];
int xh[N],w[N];
int n,c,sm;
bool vis[N]; struct love
{
int i,sum;
int cc;
}r,e,my[M]; void BFS(int s)
{
memset(vis,0,sizeof(vis));
vis[s]=1;
vector<int>::iterator it;
r.i=s;
r.sum=xh[s]; sm=max(sm,r.sum);
r.cc=c-w[s];
if(r.cc==0)
return ;
int he=0,ta=0;
my[ta++]=r;
while(he!=ta)
{
e=my[he++];
if(he==M)
he=0;
for(it=q[e.i].begin();it!=q[e.i].end();it++)
{
r=e;
int k=*it;
if(vis[k]) continue;
vis[k]=1;
r.i=k;
r.sum+=xh[k]; sm=max(sm,r.sum);
r.cc-=w[k];
if(r.cc>0)
{
my[ta++]=r;
if(ta==M)
ta=0;
}
}
}
} int main()
{
int T;
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&n,&c);
for(int i=0;i<n;i++)
{
scanf("%d%d",&xh[i],&w[i]);
}
for(int i=0;i<=n;i++)
q[i].clear();
for(int i=0;i<n-1;i++)
{
int a,b;
scanf("%d%d",&a,&b);
q[a].push_back(b);
q[b].push_back(a);
}
int Max=-1;
for(int i=0;i<n;i++)
{
sm=0;
if(q[i].size()==1)
BFS(i);
if(Max<sm)
Max=sm;
}
cout<<Max<<endl;
}
return 0;
}

树形DP代码:

#include <iostream>
#include <cstdio>
#include <vector>
#include <cstring>
using namespace std;
#define N 50500
int trap[N],val[N],n,C,vis[N],ans;
int dp[N][5][2];
vector<int>vec[N]; void DP(int u)
{
vis[u]=1;
dp[u][trap[u]][0]=dp[u][trap[u]][1]=val[u];
int v;
for(int i=0;i<vec[u].size();++i)
{
v=vec[u][i];
if(vis[v]) continue;
DP(v);
for(int j=0;j<=C;++j)
for(int k=0;j+k<=C;++k)
{
if(j!=C) // j=C的时候已经停止了,不会再往子节点跑了
ans=max(ans,dp[u][j][0]+dp[v][k][1]);
if(k!=C) // 同理
ans=max(ans,dp[u][j][1]+dp[v][k][0]);
if(j+k<C) // 0表示从子树方向往根节点跑,子树可能是非陷阱的点,
//假如j+k==C,题意要求到达C要停止,但按dp[v][k][0]记录的,还会继续跑,所以不行
ans=max(ans,dp[u][j][0]+dp[v][k][0]);
//if(j+k<C)
//ans=max(ans,dp[u][j][1]+dp[v][k][1]);
}
for(int j=0;j+trap[u]<=C;++j)
dp[u][j+trap[u]][0]=max(dp[u][j+trap[u]][0],dp[v][j][0]+val[u]);
for(int j=1;j+trap[u]<=C;++j) // 1表示从根节点往下走的,1->0是不可取的,因为算上1后,已经满C了,就不会再走了,所以不能更新
dp[u][j+trap[u]][1]=max(dp[u][j+trap[u]][1],dp[v][j][1]+val[u]);
}
}
int main ()
{
int ncase;scanf("%d",&ncase);
while(ncase--)
{
scanf("%d%d",&n,&C);
for(int i=0;i<n;++i)
vec[i].clear();
memset(vis,0,sizeof(vis));
memset(dp,0,sizeof(dp));
ans=0;
for(int i=0;i<n;++i)
scanf("%d%d",&val[i],&trap[i]);
int u,v;
for(int i=1;i<n;++i)
{
scanf("%d%d",&u,&v);
vec[u].push_back(v);
vec[v].push_back(u);
}
DP(0);
printf("%d\n",ans);
}
return 0;
}

HDU 4616 Game (搜索)、(树形dp)的更多相关文章

  1. Install Air Conditioning HDU - 4756(最小生成树+树形dp)

    Install Air Conditioning HDU - 4756 题意是要让n-1间宿舍和发电站相连 也就是连通嘛 最小生成树板子一套 但是还有个限制条件 就是其中有两个宿舍是不能连着的 要求所 ...

  2. POJ 2342 &&HDU 1520 Anniversary party 树形DP 水题

    一个公司的职员是分级制度的,所有员工刚好是一个树形结构,现在公司要举办一个聚会,邀请部分职员来参加. 要求: 1.为了聚会有趣,若邀请了一个职员,则该职员的直接上级(即父节点)和直接下级(即儿子节点) ...

  3. hdu 5452 Minimum Cut 树形dp

    Minimum Cut Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=54 ...

  4. HDU 1520 Anniversary party [树形DP]

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1520 题目大意:给出n个带权点,他们的关系可以构成一棵树,问从中选出若干个不相邻的点可能得到的最大值为 ...

  5. hdu 1520Anniversary party(简单树形dp)

    Anniversary party Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others ...

  6. HDU 3586 二分答案+树形DP判定

    HDU 3586 『Link』HDU 3586 『Type』二分答案+树形DP判定 ✡Problem: 给定n个敌方据点,1为司令部,其他点各有一条边相连构成一棵树,每条边都有一个权值cost表示破坏 ...

  7. HDU 3586.Information Disturbing 树形dp 叶子和根不联通的最小代价

    Information Disturbing Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 131072/65536 K (Java/ ...

  8. HDU 5293 Annoying problem 树形dp dfs序 树状数组 lca

    Annoying problem 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5293 Description Coco has a tree, w ...

  9. HDU - 3586 Information Disturbing 树形dp二分答案

    HDU - 3586 Information Disturbing 题目大意:从敌人司令部(1号节点)到前线(叶子节点)的通信路径是一个树形结构,切断每条边的联系都需要花费w权值,现在需要你切断前线和 ...

  10. HDU 1011 Starship Troopers 树形DP 有坑点

    本来是一道很水的树形DP题 设dp[i][j]表示,带着j个人去攻打以节点i为根的子树的最大收益 结果wa了一整晚 原因: 坑点1: 即使这个节点里面没有守卫,你如果想获得这个节点的收益,你还是必须派 ...

随机推荐

  1. encode_json 会对给定的Perl的数据结构转换为一个UTF-8 encoded, binary string.

    use JSON qw/encode_json decode_json/ ; use Encode; my $data = [ { 'name' => 'Ken' , 'age' => 1 ...

  2. uva 10127 - Ones(数论)

    题目链接:uva 10127 - Ones 题目大意:给出n,问说者少要多少为1才干够整除n. 解题思路:等于是高精度取模,直到余数为0为止. #include <cstdio> #inc ...

  3. Android JNI 编译正确 但是提示程序有错误无法运行 而且还看不到任何错误提示 的解决方法

    前几篇中一直在通过Android做JNI调用,关于JNI的配置请见:http://blog.csdn.net/watkinsong/article/details/9849973 但是前一段时间就遇到 ...

  4. oracle维护表空间和数据文件

    1:重要参考 wiki 2: oracle doc 表空间参考 3:来自dba-oracle的参考 26,27,28,29 一:oracle 表空间概念 表空间是联系数据库的物理磁盘(数据文件)和逻辑 ...

  5. Delphi 设置文件属性

    复制代码uses FileCtrl; procedure TForm1.BitBtn1Click(Sender: TObject);begin with OpenDialog1 do if Execu ...

  6. 有空研究一下OwnerDraw和三种Windows风格CS_OWNDC和CS_PARENTDC和CS_CLASSDC

    就在StdCtrls.pas, ExtCtrls.pas和Buttons.pas三个类里研究就够了,这是初步的搜索结果: ---------- 在打开的文档中查找 ---------- "G ...

  7. 中国本土管理咨询公司排名TOP50

    中国本土管理咨询公司排名TOP50 1. 北京正略钧策管理顾问有限公司 2. 北京和君咨询公司 3. 北大纵横管理咨询公司 4. 远卓管理顾问公司 5. AMT管理咨询公司 6. 华夏基石管理咨询有限 ...

  8. hdu1114

    完全背包的水题,不过今天才学动态规划,就这样啦……hahahah!!! 完全背包跟普通背包的区别是普通背包从后往前循环,以防止被替换 完全背包是从前往后循环,后面的状态会跟着之前状态的改变而改变…… ...

  9. SQL基础检测

    1.SQL 指的是? Structured Query Language 2.哪个 SQL 语句用于从数据库中提取数据? SELECT 3.哪条 SQL 语句用于更新数据库中的数据? UPDATE 4 ...

  10. 积累的VC编程小技巧之对话框

    1.用鼠标移动基于对话框的无标题栏程序的简单方法 void CVCTestDlg::OnLButtonDown(UINT nFlags, CPoint point) {    //一句话解决问题    ...