因为上次比赛sb地把一道树形dp当费用流做了,受了点刺激,用一天时间稍微搞一下树形DP,今后再好好搞一下)

基于背包原理的树形DP

poj 1947 Rebuilding Roads

题意:给你一棵树,让你求最少剪掉多少条边可以剪出一棵点数为m的子树.

解法:dp[i][j]表示i节点得到j个节点的子树至少要剪多少边,对于每个节点a和它的孩子b,如果剪掉b,则dp(s)[a][j]=dp(s-1)[a][j], 如果保留<a,b>dp(s)[a][j]=min{dp(s-1)[a][j - k] + dp[b][k]}.初始条件为dp[a][1] = 0;

为了不产生后效性,需要由大到小枚举j的值。ans=min{dp[i][m] + 1,dp[root][m]}

[java] view plaincopy print?
  1. void dfs(int a) {
  2. dp[a][1] = 0;
  3. for (int i = E[a]; i != -1; i = buf[i].ne) {
  4. int b = buf[i].be;
  5. dfs(b);
  6. num[a]+=num[b];
  7. for (int j =Math.min(m,num[a]); j > 0; j--) {
  8. dp[a][j]++;
  9. for (int k = 1; k <= j&&k<=num[b]; k++)
  10. dp[a][j] = Math.min(dp[a][j], dp[a][j - k] + dp[b][k]);
  11. }
  12. }
  13. }

void dfs(int a) {dp[a][1] = 0;for (int i = E[a]; i != -1; i = buf[i].ne) {int b = buf[i].be;dfs(b);num[a]+=num[b];for (int j =Math.min(m,num[a]); j > 0; j--) {dp[a][j]++;for (int k = 1; k <= j&&k<=num[b]; k++)dp[a][j] = Math.min(dp[a][j], dp[a][j - k] + dp[b][k]);}}}

poj 1155 TELE 

题意:其余点为转发站。客户端i愿支付的钱为pay[i],每条边需要的花费固定,问电台在保证不亏损的情况下,解法:dp[a][j] = Math.max(dp[a][j], dp[a][j - k] + dp[b][k]- buf[i].v);节点a给j个节点输送信号能赚多少钱 j k num有N座城堡,每座城堡都有一定的宝物,允许攻克M个城堡并获得里面的宝物。但有些城堡必须先攻克其他某一个特定的城堡才能攻克,问攻克M个城堡所获得的最多宝物的数量。

dp[a][j] = Math.max(dp[a][j], dp[a][k] + dp[b][j - k]);dp[a][j]代表从i开始攻克j的城堡的最大获利,初始化时dp[i][1]=i城堡内的宝贝数,dp[0][1]=0;dp[i][0]=0;ans=Max{dp[i][m],dp[0][m+1]};

------------------------------------------------------------------------------------------------------

Poj 2486 Apple Tree

题意:苹果树上有n个节点,每个节点数上有若干个苹果,问最多走m步后至多能吃多少个苹果。

解法:每个在路径上的节点有两种形态:一是以此节点为起点到达某点后不再返回,而是从此节点出发后返回再从其它孩子继续走。因此定义dp[a][j][0]为a节点第一种情况下走j步的最大获利dp[a][j][1]为a节点在第二种情况下走j步的最大获利。转移方程为:

dp[a][j][0]=Math.max(dp[a][j][0],dp[a][k][1]+dp[b][j-k-1][0]); dp[a][j][0]=Math.max(dp[a][j][0],dp[a][k][0]+dp[b][j-k-2][1]); dp[a][j][1]=Math.max(dp[a][j][1],dp[a][k][1]+dp[b][j-k-2][1])

初始化dp[i][0][1]=dp[i][0][0]=i节点的苹果数。ans=Max{0,dp[1][i][0]};

Poj 1655 balancing Act/poj 3107 Godfather

题意:一个节点的平衡因子定义为:删到此节点后形成的节点数最多的子树。求一棵树中平衡因子最大的节点。

解法,定义num[i]为i节点为根的子树的节点数max[i]为i节点孩子节点数的最大值,一个节点的平衡因子=ans= Math.max(ans, first + second);

Sgu149&&HDU2196 Computer

解法:一个点的最远路径或者是向下一直走或者是先走到父节点然后再从父节点开始走一条较长的路径。
     对于第一种情况由底向上更新求出每点的最长路径和次长路径即可;对于第二种情况,如果当前节点是父节点最长路径上的点,那么向上的最长路径=边权+父节点的次长路径,否则最长路径=边权+父节点的最长路径。得到向上的最长路径后更新最长路径和次长路径(如果更新了最长路径,需要更新一下原来向下最大孩子的状态,使它不是父节点最长路径上的点),从上向下dfs更新一下即可。

[java] view plaincopy print?
  1. int dfs(int a) {
  2. int temp, f = 0;
  3. for (int i = E[a]; i != -1; i = buf[i].ne) {
  4. int b = buf[i].be;
  5. temp = dfs(b) + buf[i].v;
  6. if (temp > first[a]) {
  7. second[a] = first[a];
  8. first[a] = temp;
  9. f = b;
  10. }
  11. else if(temp>second[a])
  12. second[a]=temp;
  13. }
  14. fid[a] = f;
  15. isf[f] = true;
  16. return first[a];
  17. }
  18. void work(int p, int a, int v) {
  19. int temp = -1;
  20. if (isf[a])
  21. temp = second[p] + v;
  22. else
  23. temp = first[p] + v;
  24. if (temp > first[a]) {
  25. second[a] = first[a];
  26. first[a] = temp;
  27. isf[fid[a]] = false;
  28. } else if (temp > second[a])
  29. second[a] = temp;
  30. for (int i = E[a]; i != -1; i = buf[i].ne) {
  31. int b = buf[i].be;
  32. work(a, b, buf[i].v);
  33. }
  34. }

int dfs(int a) {int temp, f = 0;for (int i = E[a]; i != -1; i = buf[i].ne) {int b = buf[i].be;temp = dfs(b) + buf[i].v;if (temp > first[a]) {second[a] = first[a];first[a] = temp;f = b;}else if(temp>second[a])second[a]=temp;}fid[a] = f;isf[f] = true;return first[a];}void work(int p, int a, int v) {int temp = -1;if (isf[a])temp = second[p] + v;elsetemp = first[p] + v;if (temp > first[a]) {second[a] = first[a];first[a] = temp;isf[fid[a]] = false;} else if (temp > second[a])second[a] = temp;for (int i = E[a]; i != -1; i = buf[i].ne) {int b = buf[i].be;work(a, b, buf[i].v);}}

转载于:https://www.cnblogs.com/avcs/p/6909961.html

DP Intro - Tree DP Examples相关推荐

  1. 【Codeforces613D】Kingdom and its Cities【虚树】【Tree DP】

    http://codeforces.com/problemset/problem/613/D 题意: 给出n个点的树,有q个询问,每次询问给出k个重要的点,问至少删掉多少个非重要的点,使得这个重要的点 ...

  2. 【Codeforces613D】Kingdom and its Cities【虚树】【Tree DP】倍增lca

    http://codeforces.com/problemset/problem/613/D 题意: 给出n个点的树,有q个询问,每次询问给出k个重要的点,问至少删掉多少个非重要的点,使得这个重要的点 ...

  3. 期望dp ---- B. Tree Array 思维+期望dp 逆序对期望数

    题目大意 题目大意: n(n≤200)n(n\leq200)n(n≤200)个节点的树.初始的时候,等概率随机选择一个点标记,接来随机选择一个与标记点相连的未标记点来标记,直到所有的点都被标记.根据点 ...

  4. Codeforces868E Policeman and a Tree -- DP

    令 fu,v,s1,s2f_{u,v,s_1,s_2} 表示当前在第 uu 个点,将要走到第 vv 个点,前面有 s1s_1 个罪犯,后面有 s2s_2 个罪犯,将所有罪犯抓到的最小时间. 那么如果 ...

  5. 树形dp ---- gym101667 A(贪心 + 树形dp + 两个dp方程组维护)

    题目链接 题目大意: 就是一棵5e35e35e3的树,可以选择一些点,放上基站,如果uuu上的基站价值为ddd,那么距离uuu小于等于ddd的点都会被覆盖,问使得整棵树被覆盖需要的最小价值. 解题思路 ...

  6. leetcode10 为什么p[j-1] == '*'的时候,不能用递推公式dp[i][j] = dp[i][j-1] || dp[i][j-2] || dp[i-1][j]

    因为可能会出现以下情况: "mississippi" "mis*is*p*." mississ mis*is* 符合 mississi mis*is* 符合 所 ...

  7. 【BZOJ】1076 [SCOI2008]奖励关 期望DP+状压DP

    [题意]n种宝物,k关游戏,每关游戏给出一种宝物,可捡可不捡.每种宝物有一个价值(有负数).每个宝物有前提宝物列表,必须在前面的关卡取得列表宝物才能捡起这个宝物,求期望收益.k<=100,n&l ...

  8. 牛客网dp专题 数位dp

    文章目录 数位dp 例题: NC116652 uva11038 How many 0's NC15035 送分了QAQ NC20669 诡异数字 NC20665 7的意志 NC17385 Beauti ...

  9. [SOCI2005]最大子矩阵(DP) + [JXOI2018]守卫(DP) + [CQOI2016]手机号码(数位DP)[各种DP专练]

    DP专练博客 DP专练 T1:最大子矩阵 题目 题解 代码实现 T2:守卫 题目 题解 代码实现 T3:手机号码 题目 题解 代码实现 T1:最大子矩阵 题目 这里有一个n*m的矩阵,请你选出其中k个 ...

最新文章

  1. php链接数据库地址填写ip地址,PHP使用IP地址联接MySQL数据库
  2. 第八篇:Docker镜像结构原理
  3. asio::write RuntimeError
  4. [鸟哥的Linux私房菜] X Window 与 纯文本模式的切换
  5. Storybord切换
  6. python中如何打开csv文件_在Python中从CSV文件读取数据
  7. 漫谈C++重载运算符
  8. Taro+react开发(87):图片引入
  9. Linux工作笔记-使用find和grep检索文件或子文件中是否包含指定字符串
  10. 【编译器】G++常用命令
  11. 微信小程序商城毕业设计毕设作品(8)毕业设计论文
  12. 微信小程序php后台实现
  13. win7 开机加速系列-下篇
  14. 提高github下载速度的方法
  15. 2014-7-17 NOIP模拟赛
  16. 全球及中国焦磷酸钠行业需求态势及发展趋势预测报告(2022-2027年)
  17. GPGPU基础(一):一些基本概念
  18. 初学数据库---数据库设计学习
  19. 系统背景描述_舞台灯光网络系统及光源角度资料免费分享
  20. 神经系统分类和组成图表,神经系统的组成概念图

热门文章

  1. c语言各个英文的作用,C语言最重要的知识点复习资料(国外英文资料).doc
  2. python标准输入_Python 处理标准输入
  3. java 数据库外键查询_oracle中查询所有外键引用到某张表的记录
  4. linux下怎样看设备的中断号,Linux设备驱动的中断处理
  5. mysql 及时点还原_mysqlbinglog基于即时点还原
  6. HTML+CSS+JS实现 贪吃蛇游戏源码
  7. jdk db版本_企业视频会议系统音视频通话EasyRTC-SFU版本研发中更合适的配置文件格式-TOML配置介绍 - TSINGSEE...
  8. java static方法
  9. mysql数据库表的类型介绍,mysql数据库表的类型介绍
  10. mysql 备份 windows_windows mysql 自动备份的几种方法