题目大意:给一棵带边权的有根树,每个叶子节点有权。边权表示代价,叶子节点的权值代表可以补偿多少代价。问从根节点最多可以到达多少个叶子,使得付出的总代价不大于0。

题目分析:定义状态dp(u,k)表示从u开始到达k个叶子所花费的最小代价。则状态转移方程为:

dp(u,k)=min(dp(u,k),dp(son,j)+dp(u,k-j)+u到son的代价)。

ps:要加上优化,否则超时。

代码如下:

  1. # include<iostream>
  2. # include<cstdio>
  3. # include<cstring>
  4. # include<algorithm>
  5. using namespace std;
  6.  
  7. const int N=3005;
  8. const int INF=1000000000;
  9.  
  10. struct Edge
  11. {
  12. int to,w,nxt;
  13. };
  14. Edge e[N];
  15. int n,m,cnt;
  16. int w[N];
  17. int head[N];
  18. int dp[N][N];
  19.  
  20. void add(int u,int v,int w)
  21. {
  22. e[cnt].to=v;
  23. e[cnt].w=w;
  24. e[cnt].nxt=head[u];
  25. head[u]=cnt++;
  26. }
  27.  
  28. void init()
  29. {
  30. int k,a,b;
  31. cnt=0;
  32. memset(head,-1,sizeof(head));
  33. for(int i=1;i<=n-m;++i){
  34. scanf("%d",&k);
  35. while(k--)
  36. {
  37. scanf("%d%d",&a,&b);
  38. add(i,a,b);
  39. }
  40. }
  41. for(int i=n-m+1;i<=n;++i)
  42. scanf("%d",w+i-n+m-1);
  43. }
  44.  
  45. int dfs(int u)
  46. {
  47. for(int i=0;i<=m;++i)
  48. dp[u][i]=INF;
  49. dp[u][0]=0;
  50. if(u>n-m){
  51. dp[u][1]=-w[u-n+m-1];
  52. return 1;
  53. }
  54. int tot=0;
  55. for(int i=head[u];i!=-1;i=e[i].nxt){
  56. int v=e[i].to;
  57. tot+=dfs(v);
  58. for(int j=tot;j>=1;--j)
  59. for(int k=0;k<=j;++k)
  60. dp[u][j]=min(dp[u][j],e[i].w+dp[v][k]+dp[u][j-k]);
  61. }
  62. return tot;
  63. }
  64.  
  65. void solve()
  66. {
  67. dfs(1);
  68. int ans=0;
  69. for(int i=m;i>=0;--i){
  70. if(dp[1][i]<=0){
  71. ans=i;
  72. break;
  73. }
  74. }
  75. printf("%d\n",ans);
  76. }
  77.  
  78. int main()
  79. {
  80. while(~scanf("%d%d",&n,&m))
  81. {
  82. init();
  83. solve();
  84. }
  85. return 0;
  86. }

  

POJ-1155 TELE (树形DP+分组背包)的更多相关文章

  1. [POJ 1155] TELE (树形dp)

    题目链接:http://poj.org/problem?id=1155 题目大意:电视台要广播电视节目,要经过中转机构,到观众.从电视台到中转商到观众是一个树形结构,经过一条边需要支付成本.现在给你每 ...

  2. HDU4003Find Metal Mineral[树形DP 分组背包]

    Find Metal Mineral Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65768/65768 K (Java/Other ...

  3. HDU-1011 Starship Troopers (树形DP+分组背包)

    题目大意:给一棵有根带点权树,并且给出容量.求在不超过容量下的最大权值.前提是选完父节点才能选子节点. 题目分析:树上的分组背包. ps:特判m为0时的情况. 代码如下: # include<i ...

  4. Ural-1018 Binary Apple Tree(树形dp+分组背包)

    #include<cstdio> #include<cstring> #include<iostream> #include<algorithm> #i ...

  5. hdu 1561 树形dp+分组背包

    题意:就是给定n个点,每个地点有value[i]的宝物,而且有的宝物必须是另一个宝物取了才能取,问取m个点可以获得的最多宝物价值. 一个子节点就可以返回m个状态,每个状态表示容量为j(j<=m) ...

  6. 【P2015】二叉苹果树 (树形DP分组背包)

    题目描述 有一棵苹果树,如果树枝有分叉,一定是分2叉(就是说没有只有1个儿子的结点) 这棵树共有N个结点(叶子点或者树枝分叉点),编号为1-N,树根编号一定是1. 现在这颗树枝条太多了,需要剪枝.但是 ...

  7. poj2486 Apple Tree (树形dp+分组背包)

    题目链接:https://vjudge.net/problem/POJ-2486 题意:一棵点权树,起点在1,求最多经过m条边的最大点权和. 思路: 树形dp经典题.用3维状态,dp[u][j][0/ ...

  8. hdu1561 The more, The Better 树形DP+分组背包

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1561 思路: 典型的树形背包题目: 定义dp[i][j]表示以i为根节点,攻打j个城堡的获得的财宝的最 ...

  9. POJ 1947Rebuilding Roads(树形DP + 01背包)

    题目链接 题意:给出一个树形结构,求P个节点的子树最少要去掉几条边 分析:DP[root][j] 表示 以第 root 个为根节点, 包含j 个节点需要去掉几条边.那么对于 root 这个根节点来说, ...

随机推荐

  1. Visual studio 2013的安装和单元测试

    vs2013安装过程: 简单的单元测试: 1.创建新的c#类库 2.创建单元测试 3.测试结果 单元测试结束

  2. web安全测试-AppScan

    安全测试应该是测试中非常重要的一部分,但他常常最容易被忽视掉. 尽管国内经常出现各种安全事件,但没有真正的引起人们的注意.不管是开发还是测试都不太关注产品的安全.当然,这也不能怪我们苦B的“民工兄弟” ...

  3. 苹果推送APNS自己总结

    开发状态服务器地址 gateway.sandbox.push.apple.com 2195 产品状态服务器地址 gateway.push.apple.com         2195 Developm ...

  4. poj2137 dp

    //Accepted 228K 32MS //dp[k][i][j] 表示从1的k号节点到i的j号节点的最小花费 //dp[k][i][j]=min(dp[k][i-1][h]+cost) cost为 ...

  5. ubuntu下openoffice开发环境配置

    安装openoffice或者liboffice 路径:/usr/lib/openoffice/program ,soffice 开启服务: 安装JDK 其默认路径:jdk7 版本号:1.7...,jd ...

  6. 2016 - 1 - 20 runloop学习(2)

    一:CFRunLoopModeRef 1. CFRunLoopModeRef带表RunLoop的运行模式 2. 一个Runloop可以有若干个mode,每个mode又包含若干个sourse,timer ...

  7. os.system和os.popen

    使用os.popen调用test.sh的情况: python调用Shell脚本,有两种方法:os.system(cmd)或os.popen(cmd),前者返回值是脚本的退出状态码,后者的返回值是脚本执 ...

  8. linux命令:pwd

    1.介绍: pwd可以查看目录的完整路径,全称是Print Working Directory,. 2.命令格式 pwd [选项] 3.命令作用 查看目录的完整路径 4.常用选项 -L 当路径为链接路 ...

  9. ASP.NET之Ajax系列(一)

    我们在Web开发中经常会接触到Ajax技术,同时Ajax技术也有很多种实现方式,那么,我们今天从第一种方式说起:ASP.NET原生控件实现Ajax. ASP.NET原生控件用于Ajax技术的主要是Up ...

  10. Windows10中无法打开这个应用的解决方案

    报错的图: