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

永州建设学校官方网站企业小程序制作的公司

永州建设学校官方网站,企业小程序制作的公司,网页设计与网站建设大作业,如何删除网站备案号动态规划解决最小下降路径和问题 1. 题目链接 LeetCode 931. 最小下降路径和 2. 题目描述 给定一个 n x n 的整数矩阵 matrix,找到一条从第一行到最后一行的下降路径,使得路径上的数字和最小。下降路径可以从第一行的任意元素出发,每一步…

动态规划解决最小下降路径和问题

1. 题目链接

LeetCode 931. 最小下降路径和

2. 题目描述

给定一个 n x n 的整数矩阵 matrix,找到一条从第一行到最后一行的下降路径,使得路径上的数字和最小。下降路径可以从第一行的任意元素出发,每一步可以选择位于下一行正下方、左下方或右下方的元素。例如,位于 (i, j) 的元素可以下降到 (i+1, j-1)(i+1, j)(i+1, j+1)

3. 示例分析

示例输入

matrix = [[2,1,3],[6,5,4],[7,8,9]]

输出13
解释:最小下降路径为 1 → 5 → 7,路径和为 1 + 5 + 7 = 13

4. 算法思路

动态规划(Dynamic Programming)

使用动态规划解决该问题的核心思想是:定义 dp[i][j] 表示从第一行到达第 i 行第 j 列的最小路径和。为了处理边界条件(如矩阵边缘的列),我们扩展 dp 数组的边界,使其维度为 (n+1) x (n+2)

状态转移方程

对于每个位置 (i, j),其路径和的最小值由上一行的三个可能的位置决定:

dp[i][j] = matrix[i-1][j-1] + min(dp[i-1][j-1], dp[i-1][j], dp[i-1][j+1])

其中,matrix[i-1][j-1] 是当前位置的值,dp[i-1][...] 是上一行左、中、右三个位置的路径和的最小值。

初始化
  • dp[0][...] = 0:第一行的所有位置初始化为0,表示从虚拟的第0行出发的路径和为0。
  • 其余位置初始化为 INT_MAX,表示尚未计算。

5. 边界条件与注意事项

  1. 矩阵大小为1的情况:当 n=1 时,直接返回矩阵中唯一的元素。
  2. 索引转换:由于 dp 数组比原矩阵多一圈,访问 matrix 时需要将索引调整为 i-1j-1
  3. 处理边缘列:在矩阵的最左列(j=1)和最右列(j=n),需要确保不会访问到无效的列(如 j=0j=n+1),此时这些位置的 dp 值为 INT_MAX,不影响取最小值。

6. 代码实现

class Solution {
public:int minFallingPathSum(vector<vector<int>>& matrix) {int n = matrix.size();vector<vector<int>> dp(n + 1, vector<int>(n + 2, INT_MAX));// 初始化:从虚拟的第0行出发,路径和为0for (int j = 0; j < n + 2; j++) dp[0][j] = 0;for (int i = 1; i <= n; i++) {for (int j = 1; j <= n; j++) {// 状态转移:取上一行左、中、右的最小值dp[i][j] = matrix[i - 1][j - 1] + min(min(dp[i - 1][j - 1], dp[i - 1][j]), dp[i - 1][j + 1]);}}// 遍历最后一行,寻找最小值int ret = INT_MAX;for (int j = 0; j < n + 2; j++) {ret = min(ret, dp[n][j]);}return ret;}
};

代码解释

  1. 初始化 dp 数组:第0行初始化为0,其他位置为 INT_MAX
  2. 填充 dp 数组:遍历每一行,根据上一行的三个相邻位置的最小值更新当前值。
  3. 获取结果:遍历最后一行的所有列,找到最小值作为最终结果。

通过这种动态规划的方式,时间复杂度为 O(n²),空间复杂度为 O(n²),能够高效解决该问题。

http://www.dtcms.com/wzjs/575043.html

相关文章:

  • 机械建设网站制作网页设计与制作教程第六版课后答案
  • 潍坊手机网站做直播网站找哪个网站好
  • 新手怎么做html5网站php网站开发经理招聘
  • 成都网站建设设计公司排名王占山七一勋章颁奖词
  • 广州专业的做网站公司wordpress个人站
  • 传播建设网站做网站要找什么人
  • 哔哩哔哩网站国家企业信用信息公示系统官网站
  • 自己做网站系统首选平台做钉子出口哪个网站好
  • 遵义公司网站搭建多少钱定制软件安卓
  • 深圳系统开发高端网站建设肃宁做网站价格
  • 哪个网站做婚礼邀请函好店铺运营计划方案
  • 网站建设网络营销网站首页的图标是怎么做的
  • 网站查询服务器wordpress 电子书主题
  • 做网站的装饰标语商城多用户源码
  • 九江专业制作网站小程序电子商务系统的构成
  • 抚顺网站设计wowslider wordpress
  • 企业网站的建设电话咨询西乡专业做网站公司
  • 网站域名放国外宁波建设网网点
  • 蓝顿长沙网站制作公司国内永久免费建站
  • 网站建设胶州广西南宁市网站制作公司
  • 安远网站建设网站开发怎么入账
  • 潍坊制作网站公司兴义网站开发公司
  • 学做电商需要什么条件搜索引擎优化关键词
  • 网站做百度竞价的标志沈阳电商网站建设
  • seo网站建设视频建设网站一般多钱
  • 网站基础风格创建网站建设1000zhu
  • 江苏省网站建设与管理历年自考试题代理注册公司条件
  • 怎么做百度提交入口网站聊天软件开发需要多少钱
  • 用网站做淘客怎么赚钱广告优化师的职业规划
  • 大连网站建设公司哪家好小红书营销