算法动态规划
动态规划 Dynamic Programming
- Wiki 定义: https://en.wikipedia.org/wiki/Dynamic_programming
-
“Simplifying a complicated problem by breaking it down into simpler sub-problems” (in a recursive manner)
-
Divide & Conquer + Optimal substructure
分治 + 最优子结构
关键点
动态规划 和 递归或者分治 没有根本上的区别(关键看有无最优的子结构)
共性:找到重复子问题
差异性:最优子结构、中途可以淘汰次优解
例题
- 最优子结构 opt[n] = best_of(opt[n-1], opt[n-2], ...)
-
储存中间状态:opt[i]
-
递推公式(美其名曰:状态转移方程或者 DP 方程)
Fib: opt[i] = opt[n-1] + opt[n-2]
二维路径:opt[i,j] = opt[i+1][j] + opt[i][j+1] (且判断a[i,j]是否空地)
打赏作者
您将是第一位评论人!