本质 : 记忆化搜索
避免重复计算
多重循环vs记忆化搜索
多重循环:可以不用递归 可以对空间复杂度进行优化
步骤:初始化,循环,终点
什么情况下使用动态规划?
- 求最大最小值、最优值
- 判断是否可行
- 统计方案个数
什么情况下不会使用动态规划?
- 求出所有 具体 的方案 而非方案个数
- 输入数据是一个集合 而不是一个序列 跟顺序无关
- 暴力算法的复杂度已经是多项式级别
动态规划擅长优化指数级别到多项式复杂度
本质 : 记忆化搜索
避免重复计算
多重循环vs记忆化搜索
多重循环:可以不用递归 可以对空间复杂度进行优化
步骤:初始化,循环,终点
什么情况下使用动态规划?
什么情况下不会使用动态规划?