2017.11.19第十二周周总结

这个周,周末没有比赛,这几天也都在做树形dp了  现在为止做了12个题了,,遇到很多题意一样的题,

都运用了dfs和背包,dfs是深搜的一条枝到叶子,背包是对于当前节点,对他的直系子节点进行01背包(选或者不选)

感觉现在就两种模板

一种是不定根节点

找子节点,根据父子代的关系推出状态转移方程就行

难点是推状态转移方程
双向的定一个look【】,记录是否便历过,存struct时,存双向的
dfs 的for循环的是兄弟节点,以当前点为根节点,带状态转移方程,回溯~

一般情况下dfs在方程的前面

特殊的有apple  tree是三维的dp数组,因为存在返回节点的情况,第三维存的是是否返回位置,不返回时,包括(当前点不反回且子节点不返回)(当前点不返回,但子节点返回) 节点之间相互独立,可依次考虑

再一种就是每个点分别为根节点时的比较情况

在加上一次dfs循环,找当前结点与父节点之前的关系,例如B,E,要考虑每一个点为根节点的情况,只要再推一个状态转移方程即可,一般情况先,方程在dfs的前面


还看到一个题,是到从指定点开始,到指定点结束,寻找最值,这个题还没有做出来,觉得可能有点新意

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值