当前位置: 首页 > news >正文

长沙网站建设开发h5页面制作平台

长沙网站建设开发,h5页面制作平台,网络设备具体有哪些,css网站导航菜单1. 下降路径最小和 题目链接: 931. 下降路径最小和 - 力扣(LeetCode)https://leetcode.cn/problems/minimum-falling-path-sum/description/ 2. 算法原理 状态表示:以莫一个位置位置为结尾 dp[i,j]表示:到…

1. 下降路径最小和

题目链接:

931. 下降路径最小和 - 力扣(LeetCode)icon-default.png?t=O83Ahttps://leetcode.cn/problems/minimum-falling-path-sum/description/

 

 


2.  算法原理 

状态表示:以莫一个位置位置为结尾

   

dp[i,j]表示:到达[i,j]位置的时候,此时的最小下降路径

2. 状态转移方程

  

根据最近的一步来划分问题:

      

                                以最小的下降路径到达A位置,然后再走一步到达目的地 

到达dp[i][j]有三种情况:

                               1. 从左上方位置过来:[i-1,j-1] -> [i,j],dp[i-1,j-1] + m[i][j]

                                                                                                 (缩写为x)     

     

                               2. 从正上方位置过来:[i-1,j] -> [i,j],dp[i-1,j] + m[i][j]

                                                                                                 (缩写为y)

     

                               3. 从右上方位置过来:[i-1,j+1] -> [i,j],dp[i-1,j+1] + m[i][j]

                                                                                                    (缩写为z)

     

本题的状态转移方程是:dp[i][j] = min(x,y,z)+m[i][j]

3. 初始化 :把dp表填满不越界,让后面的填表可以顺利进行

   

我们可以在上面的一行和左边还有右边的一列再额外的加上一行和两列的虚拟节点

    

原始矩阵里第一行的值是不能被改变的,不然会影响到最终结果,所以第一行的虚拟节点应该全部初始化为0,而左右两列不能初始化为0,因为为0的话就可能会参与最小值的计算,会影响到最终结果,所以应该初始化为正无穷大

    

本题的下标映射关系:因为本题给了一个矩阵,而我们又额外的加上一行和两列的虚拟节点,所以我们的下标都统一往右下角移动了一位,如果想找回之前对应的位置,那么下标需要进行统一减1(横纵坐标)

4. 填表顺序 

    

本题的填表顺序是:从上往下填写每一行,每一行的值是从左往右

5. 返回值 :题目要求 + 状态表示    

    

本题的返回值是:最后一行里面的最小值


3.代码 

动态规划的固定四步骤:1.  创建一个dp表

                                        2. 在填表之前初始化

                                        3. 填表(填表方法:状态转移方程)

                                        4. 确定返回值 

class Solution {
public:int minFallingPathSum(vector<vector<int>>& matrix) {//本题是方形,所以不需要mint  n = matrix.size();//多加了一行两列,初始化先把虚拟节点都初始化为正无穷大vector<vector<int>>dp(n + 1, vector<int>(n + 2, INT_MAX));//将虚拟节点的第一行初始化为0for (int j = 0; j < n + 2; j++) dp[0][j] = 0;//额外的加上一行和两列的虚拟节点,所以从1开始for (int i = 1; i <= n; i++)for (int j = 1; j <= n; j++)//这里的matrix[i-1][j-1]也是加上一行和一列的虚拟节点,所以要横纵-1dp[i][j] = min(dp[i - 1][j - 1], min(dp[i - 1][j], dp[i - 1][j + 1]))+ matrix[i - 1][j - 1];//返回最后一行里面的最小值//定义一个临时变量ret,不能将ret的的值定义为0,不然会影响到最终结果int ret = INT_MAX;for (int j = 1; j <= n; j++)ret = min(ret, dp[n][j]);//找到最后一行的最小和return ret;}
};


完结撒花~

http://www.ritt.cn/news/17631.html

相关文章:

  • 正能量软件不良网站下载手机如何制作一个网页链接
  • 苏州好的做网站的公司有哪些app推广赚钱平台
  • 珠海做网站推广公司推广方案应该有哪些方面
  • 微信音乐做mp3下载网站网络营销技巧和营销方法
  • 网络营销章节测试答案网络优化工程师骗局
  • 泰安企业网站seo昆明网站seo优化
  • 怎么做二级域名网站搜索引擎大全排行榜
  • 网站建设方案-奢侈品seo优化教程视频
  • 大学交作业wordpress广东seo快速排名
  • 天津自动网站建设调试今日热点新闻头条国内
  • 浙江标力建设集团网站开车搜索关键词
  • 潼关县住房和城乡建设局网站seo是做什么工作的
  • 网站后台改互联网营销师证书怎么考多少钱
  • 佛山网站建设与设计公司爱站长尾词挖掘工具
  • 国家水资源监控能力建设网站seo 优化顾问
  • 景德镇建设局网站成都网络推广运营公司
  • 做物流网站的公司哪家好seo智能优化
  • 成都装修网需要优化的网站有哪些
  • WordPress 左边导航seo问答
  • 制作网站的心得体会营销型网站建设公司价格
  • liunx做网站跳转哈尔滨电话本黄页
  • 政府门户网站建设合同郑州专业seo首选
  • 在线做qq空间的网站网站托管维护
  • 自己做网站教学视频教程seo免费推广
  • 咋样做网站搭建网站的步骤和顺序
  • 最好科技广州网站建设微信scrm
  • 好知网做网站百度人工服务24小时电话
  • 营销型网站建设818gx网球排名即时最新排名
  • 建筑公司电话号码哪里有整站优化
  • 广州建站网站前十名app推广项目