动态规划--树形DP

动态规划--树形DP


 1、什么是树型动态规划 
顾名思义,树型动态规划就是在“树”的数据结构上的动态规划,平时作的动态规划都是线性的或者是建立在图上的,线性的动态规划有二种方向既向前和向后,相应的线性的动态规划有二种方法既顺推与逆推,而树型动态规划是建立在树上的,所以也相应的有二个方向:
    1、叶->根:在回溯的时候从叶子节点往上更新信息
    2、根 - >叶:往往是在从叶往根dfs一遍之后(相当于预处理),再重新往下获取最后的答案。
    不管是从 叶->根 还是从 根 - >叶,两者都是根据需要采用,没有好坏高低之分。

2、树形动态规划的优美之处
树真的是一种特别特别优美的结构!用来做动态规划也简直是锦上添花再美不过的事,因为树本身至少就有“子结构”性质(树和子树);也本身就具有递归性。所以在树上DP其实是其所当然的事,相比线性动态规划来讲,转移方程更直观,更易理解。

3、难点
  1. 和线性动态规划相比,树形DP往往是要利用递归的,所以对递归不熟悉的同学,是一道小小的障碍,说是小小的,因为要去理解也不难.
  2. 细节多,较为复杂的树形DP,从子树,从父亲,从兄弟…已经一些小的要处理的地方,脑子不清晰的时候做起来颇为恶心
  3. 状态表示和转移方程,也是真正难的地方。做到后面,树形DP的老套路都也就那么多,难的还是怎么能想出转移方程,状压DP、概率DP这些特别的DP应该说做到最后都是这样!
通过dfs维护从根到叶子或从叶子到根的状态转移
********************************************************************************************************************
1.    hdu 4123 Bob's Race  树形dp+RMQ
2.     hdu 4514   求树的直径+并查集判环
3.    hdu 4126 Genghis Kehan the Conqueror   Prim+树形dp 比较经典
4.    hdu 4714 Tree2Cycle  思维
5.     hdu 3660 Alice and Bob's Trip  有点像对抗搜索
6.    
  • 3
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值