Dynamic Programming

Dynamic Programming 在算法中是一个比较实用的算法, 其原理是把一个大问题拆解成多个小问题,找到子问题的最优解,组合后就变成大问题的最优解。Dynamic Programming 有两种设计模式,一种是 bottom-up,另一个是 top-down。这两种设计模式各有其优点,下面我们来看一下两种设计模式。

Bottom-Up

Bottom-Up 设计模式是从下往上,换而言之,每个基础的 case 会很详细,然后不断组合后变成最终的大 case。从代码层面上,我们从最基础的 case 开始递归,然后不断前进。

Top-Down

Top-Down 是从上往下的设计模式,一开始我们会有一个比较不那么具体的方向,然后不断抽丝剥茧,不断细致化,最终获得最优解。从代码角度来看,我们很有可能从最后一个 case 开始算起,然后通过递归,遇到条件符合的进行下一层底柜,不符合的回朔之后,找到下一个条件,开始递归。

总结

DP 算法在实际场景中是实用的,大家要学会灵活实用 DP,找到 base condition 之后,从前往后或者从后往前都是一种解决思路。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值