8.24收获

1.要经常数学推导,将不好维护的数据转化成便于维护的数值,同时不影响答案的正确性!!!

2.dp答案一定正确,但是过程不一定正确;在设计dp时也可以设计这种dp保证答案的正确性

3.虚拟原点,虚拟终点,虚拟根节点(将本互不相关的点/树拼接到一起,便于进行树形dp)

4.有依赖的背包问题可以转换成分组背包,u为节点,对子树进行二进制表示,每一个二进制之间互斥,极为分组背包,但pow(2,k)太大,O(N*2^k*V)优化为(N*V*V);

但对于V大而k小的情况,即可这样求解,如金明的预算方案,k最大为2,但V极大,故采用这种方式;

5.递归建树

6.答案导向,为了答案而定义dp状态以及维护的值

        为了答案而选择算法,数据结构

        而与求解答案无关的步骤/状态无需记录

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值