二叉苹果树

题目 
有一棵苹果树,如果树枝有分叉,一定是分2叉(就是说没有只有1个儿子的结点) 
这棵树共有N个结点(叶子点或者树枝分叉点),编号为1-N,树根编号一定是1。 
我们用一根树枝两端连接的结点的编号来描述一根树枝的位置。下面是一颗有4个树枝的树 
   2   5 
    / / 
     3   4 
      / / 
       1 
现在这颗树枝条太多了,需要剪枝。但是一些树枝上长有苹果。 
给定需要保留的树枝数量,求出最多能留住多少苹果。

输入格式 
第1行2个数,N和Q(1<=Q<= N,1<N<=100)。 
N表示树的结点数,Q表示要保留的树枝数量。接下来N-1行描述树枝的信息。 
每行3个整数,前两个是它连接的结点的编号。第3个数是这根树枝上苹果的数量。 
每根树枝上的苹果不超过30000个。

输出格式 
一个数,最多能留住的苹果的数量。

样例输入

5 2

1 3 1

1 4 10

2 3 20

3 5 20

样例输出

21

------------------------------ 
分析:因为树是二叉的,所以状态转移方程很容易写出,

f[i][m]表示第i个节点下,共保留m个树枝的最大苹果数目。

ch[i,L]表示i树左边的枝条集合, ch[i,R]表示i树右边的枝条集合

f[ch[i,L],n]表示在i树左边的枝条集合中选取n个枝条的最大苹果数目

f[ch[i,R],n]表示在i树右边的枝条集合中选取n个枝条的最大苹果数目

方程:f[i][m]=max{
f[ch[i,L],n]+f[ch[i,R],m-n]]} (
0<=n<=m) 其中L,R为i的左右子树

公式太抽象,举个例子

对于如下苹果树

有7个节点a,b,c,d,e,f,g; 有6条边,边的权重分别为5,24,20,30,21,27

求f[a][4],即只保留4个枝条,最多留下多少苹果?

根据公式,f[a][4] = max

{

f[ch[a,L],3]+f[ch[a,R],1],

f[ch[a,L],2]+f[ch[a,R],2],

f[ch[a,L],1]+f[ch[a,R],3]

}

其中f[ch[a,L],3]=f[b,2]
+ 5 (枝条ab的权重);

所以

f[a][4] = max

{

5+f[b][2]+24,

5+f[b][1]+24+f[c][1],

5+24+f[c][2]

}

f[b][2]=50,f[b][1]=30,f[c][1]=27,f[c][2]=48

f[a][4] =f[ch[a,L],2]
+
f[ch[a,R],2]=

5+f[b][1]+24+f[c][1]=86;

题目2:看守道路

一个城堡的所有的道路形成一个n个节点的树,如果在一个节点上放上一个士兵,那么和这个节点相连的边就会被看守住,问把所有边看守住最少需要放多少士兵?

这个题目,是典型的树形动态规划

求解:
dproot[i]表示以i为根的子树,在i上放置一个士兵,看守住整个子树需要多少士兵。
all[i]表示看守住整个以i为根的子树需要多少士兵。(不一定要在i上,放置士兵)

状态转移方程:
叶子节点:dproot[k]=1; all[k]=0;

all[k]=0表示要看守住含有叶子节点道路,一定可以不用在叶子节点放置守卫
非叶子节点:
dproot[i]=1+∑all[j](j是i的儿子);
all[i]=min(dproot[i],∑dproot[j](j是i的儿子));

这个题目还是比较简单的,如果把题目中树改为看守一个n个节点的图呢?

DP Intro - Tree DP的更多相关文章

  1. DP Intro - Tree DP Examples

    因为上次比赛sb地把一道树形dp当费用流做了,受了点刺激,用一天时间稍微搞一下树形DP,今后再好好搞一下) 基于背包原理的树形DP poj 1947 Rebuilding Roads 题意:给你一棵树 ...

  2. DP Intro - Tree POJ2342 Anniversary party

    POJ 2342 Anniversary party (树形dp 入门题) Anniversary party Time Limit: 1000MS   Memory Limit: 65536K To ...

  3. HDU5293(SummerTrainingDay13-B Tree DP + 树状数组 + dfs序)

    Tree chain problem Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Other ...

  4. HDU3534(SummerTrainingDay13-C tree dp)

    Tree Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  5. Partial Tree(DP)

    Partial Tree http://acm.hdu.edu.cn/showproblem.php?pid=5534 Time Limit: / MS (Java/Others) Memory Li ...

  6. 96. Unique Binary Search Trees (Tree; DP)

    Given n, how many structurally unique BST's (binary search trees) that store values 1...n? For examp ...

  7. DP Intro - poj 1947 Rebuilding Roads(树形DP)

    版权声明:本文为博主原创文章,未经博主允许不得转载. Rebuilding Roads Time Limit: 1000MS   Memory Limit: 30000K Total Submissi ...

  8. HDU 4359——Easy Tree DP?——————【dp+组合计数】

    Easy Tree DP? Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)To ...

  9. TYOI Day1 travel:Tree dp【处理重复走边】

    题意: 给你一棵树,n个节点,每条边有长度. 然后有q组询问(u,k),每次问你:从节点u出发,走到某个节点的距离mod k的最大值. 题解: 对于无根树上的dp,一般都是先转成以1为根的有根树,然后 ...

随机推荐

  1. Android sutdio单元测试 简单使用步骤

    1.简介 单元测试(unit testing),是指对软件中的最小可测试单元进行检查和验证.比如一个函数,一个方法等 2.添加依赖 dependencies { testCompile 'junit: ...

  2. Redis 一个很诡异的问题(部署)

    使用Redis并用window服务的方式 运行时.突然报错  在启动进程意外中止 解决方案: 调试了很久 发现居然是在 Logfile的配置中的问题. 错误的logfile logfile " ...

  3. 今天遇到的传入的表格格式数据流(TDS)远程过程调用(RPC)协议流不正确的解决方案

    传入的表格格式数据流(TDS)远程过程调用(RPC)协议流不正确.参数 3 ("@UserName"): 数据类型 0xE7 的数据长度或元数据长度无效. 今天在做数据同步的时候遇 ...

  4. 解决golang windows调试问题:Could not determine version number: could not find symbol value for runtime.buildVersion

    版本信息: go:1.8.3 windows: win7/64 idea-go-plugin:171.4694.61 在windows下,使用dlv进行调试的时候,如果golang程序引入了c模块,比 ...

  5. html5 video微信浏览器视频不能自动播放

    html5 video微信浏览器视频不能自动播放 一.微信浏览器(x5内核): 1.不能自动播放 2.全屏 3.最顶层(z层的最顶层) 二.ios系统解决方案:(无phone手机未测试) <au ...

  6. ES聚合报错

    在测试Elasticsearch聚合的时候报了一个错误.具体如下: GET /megacorp/employee/_search { "aggs": { "all_int ...

  7. ListBox Dock Fill 总是有空隙的问题

    ListBox Dock设置了Fill, Right等 设计界面如己所愿,但是实际运行时,底部总是有不小的空隙. 原因是ListBox有一个属性: IntergralHeight 默认为True 此属 ...

  8. 特殊用途语言特性(默认实参/内联函数/constexpr函数/assert预处理宏/NDEBUG预处理变量)

    默认实参: 某些函数有这样一种形参,在函数的很多次调用中它们都被赋予一个相同的值,此时,我们把这个反复出现的值称为函数的默认实参.调用含有默认实参的函数时,可以包含该实参,也可以省略该实参. 需要特别 ...

  9. 老男孩Day16作业:登录、注册、后台管理页面(动态)

    一.作业需求: 1.后台管理主界面(左边菜单框.(全选.反选)框.返回顶部按钮) 2.老男孩登录.注册页面 二.博客地址:https://www.cnblogs.com/catepython/p/93 ...

  10. SDUT OJ 顺序表应用4:元素位置互换之逆置算法

    顺序表应用4:元素位置互换之逆置算法 Time Limit: 10 ms Memory Limit: 570 KiB Submit Statistic Discuss Problem Descript ...