题目大意:给定一棵 N 个节点的无根树,每个节点有一个重量和一个价值,现给出一些单位,每个单位可以接受 20 个重量单位,求如何分配这些单位,使得获得的价值最大。

题解:dp 好题qwq。。真的毒瘤。

状态转移很好设计,\(dp[i][j]\) 表示以 i 为根节点的子树中,分配 j 个单位可以获得的最大价值是多少,转化成分组背包。

需要注意的点如下:

  • 对于公式$$\lfloor {n+m-1\over m} \rfloor$$与公式$$\lfloor {n-1\over m} \rfloor+1$$并不是完全等价的,对于 n 为 0 的时候,只有第一个公式是对的。
  • 对于 dp 过程中,当前节点价值的计入不能仅仅更新单个dp值,应整体更新所有可以更新的值,最好将更新子树根节点的操作放在递归最后进行。

代码如下

#include <bits/stdc++.h>
#define pb push_back
using namespace std;
const int maxn=110; vector<int> G[maxn];
int n,m,bug[maxn],brain[maxn],dp[maxn][maxn]; void dfs(int u,int fa){
int num=(bug[u]+19)/20;
for(auto v:G[u]){
if(v==fa)continue;
dfs(v,u);
for(int j=m;j>=num;j--)
for(int k=1;k<=j-num;k++)
dp[u][j]=max(dp[u][j],dp[v][k]+dp[u][j-k]);
}
for(int i=num;i<=m;i++)dp[u][i]+=brain[u];
}
void read_and_parse(){
for(int i=1;i<=n;i++)scanf("%d%d",&bug[i],&brain[i]);
for(int i=1;i<n;i++){
int x,y;
scanf("%d%d",&x,&y);
G[x].pb(y),G[y].pb(x);
}
}
void solve(){
if(!m)return (void)puts("0");
dfs(1,0);
printf("%d\n",dp[1][m]);
}
void init(){
memset(dp,0,sizeof(dp));
for(int i=1;i<=n;i++)G[i].clear();
}
int main(){
while(scanf("%d%d",&n,&m)&&n!=-1&&m!=-1){
init();
read_and_parse();
solve();
}
return 0;
}

最新文章

  1. Win10商店东方财富网 UWP版更新,支持平板,PC,手机
  2. android 弹出对话框之四周变暗处理方式
  3. 数据库实现多站点共享Session
  4. iOS学习10之OC类和对象
  5. Django concept
  6. MVC+Ef项目(3) 抽象数据库访问层的统一入口;EF上下文线程内唯一
  7. 【Unity入门】场景、游戏物体和组件的概念
  8. CentOS如何分区
  9. BZOJ_1614_ [Usaco2007_Jan]_Telephone_Lines_架设电话线_(二分+最短路_Dijkstra/Spfa)
  10. hdoj 4612 Warm up【双连通分量求桥&amp;&amp;缩点建新图求树的直径】
  11. 服务端生成word并压缩打包下载
  12. OC 字符和日期的互转
  13. 关于Alipay支付宝接口(Java版)
  14. java System.currentTimeMillis()毫秒值和具体日期值互相转换
  15. g4e基础篇#6 了解Git历史记录
  16. nyoj585 取石子(六) Nimm博弈
  17. 浅谈Java的主要学习要点_上海尚学堂java培训课程思维导图
  18. Python3数据类型及转换
  19. 一文了解Python中的判断语句
  20. dubbo注册到zookeeper

热门文章

  1. redis源码分析之数据结构:跳跃表
  2. 【ZT】Enhancement Framework – Introduction
  3. cocos2dx基础篇(23) 粒子系统CCParticleSystem
  4. Kaggle试水之泰坦尼克灾难
  5. illustrator 偏方
  6. selenium—隐式等待和显式等待
  7. sql server优化方向?
  8. c语言程序命名规范:函数、变量、数组、文件名
  9. Nginx_Ubuntu
  10. HDU-4332-Constructing Chimney