动态规划之路径规划01
前⾔:虽然⾃⼰做过⼏个动态规划的题⽬,看过题解后也能做出⼏个⼆维的路径问题,主要是对dfs进⾏优化。但是还是有点知其然不知其所以然的感觉,有两个⽉左右没做dp,现在让我写对⼀个⼆维路径dp都困难。所以开这个专题系统学习dp。 感谢:宫⽔三叶
本笔记根据三叶⼤佬的刷题⽇记进⾏学习记录。
动态规划解决什么样的问题?
药用铝箔
答:仅关⼼某个状态,⽽不关系状态如何转移过来(这句话很深奥,仔细体会)。常与dfs等搜索结合在⼀起,会保存⼦状态的解,且仅访问/遍历/执⾏⼀次,后续重复访问可直接利⽤此结果。 动态规划有相当多种类,其中最常见的就是路径问题和背包问题
⾸先从路径问题开始着⼿
解决路径动态规划的⽅法:
(以下是之前我⾃⼰总结的经验)
1.确定状态转移⽅程。
2.路径问题中遍历的⽅向。
激光器芯片
做了专题训练后的总结:
1.迭代⽅程
2.迭代⽅向
与遍历的⽅向和路径的⽅向选择有关
3.初始条件
⼀般是最开始源点对应的dp值,赋值操作
4.边界条件
边界时的迭代⽅程和⼀般迭代⽅程有⼀点差异
dp第⼀题试试⼿:
class Solution {
public:
控制器外壳
int uniquePaths(int m, int n) {
int a[m][n];
a[0][0]=1;
//迭代⽅程:a[m][n]=a[m-1][n]+a[m][n-1]; for(int i=0;i<m;i++){
for(int j=0;j<n;j++){
龙吸水设备
if(i>0 && j>0){
a[i][j]=a[i-1][j]+a[i][j-1];
}else if(i>0){
a[i][j]=a[i-1][j];
}else if(j>0){
a[i][j]=a[i][j-1];
}
}
}
return a[m-1][n-1];
}
};
烷基叔丁基醚本题迭代⽅程:a[m][n]=a[m-1][n]+a[m][n-1]迭代⽅向:右和下电话报警系统
边界情况:上边缘,左边缘