动态规划算法求解矩阵最小路径和问题,动态规划 矩阵最短路径

  动态规划算法求解矩阵最小路径和问题,动态规划 矩阵最短路径

  BM68矩阵的最小路径和

  知识点数组的动态编程

  描述一个给定的n * m矩阵A,从左上角开始,一次只能向右或向下,最后到达右下角。路径上的所有数字加起来就是路径和,输出所有路径中最小的路径和。

  数据范围:满足矩阵中的任何值。

  需求:时间复杂性

  例如,当输入[[1,3,5,9],[8,1,3,4],[5,0,6,1],[8,8,4,0]]时,对应的返回值为12,选择的最小求和路径如下图所示:

  示例1输入:

  [[1,3,5,9],[8,1,3,4],[5,0,6,1],[8,8,4,0]]复制返回值:

  12份

  2示例输入:

  [[1,2,3],[1,2,3]]复制返回值:

  7问题解决方案

  状态转换方程:

  dp[i,j]=min(dp[i - 1][j],dp[i][j - 1])矩阵[i][j]

  代码如下:

  #包含位/标准数据。h

  使用命名空间std

  int minPathSum(向量向量int矩阵)

  {

  if (matrix.size()==0 matrix[0]。size()==0)

  {

  返回0;

  }

  int m=matrix . size();

  int n=matrix[0]。size();

  std:vector std:vector int dp(m,std:vector int (n,0))。

  for(int I=0;我是m;我)

  {

  for(int k=0;I n;k)

  {

  如果(k==0)

  {

  如果(i==0)

  {

  dp[i][k]=矩阵[I][k];

  }

  其他

  {

  dp[i][k]=dp[i - 1][k]矩阵[I][k];

  }

  }

  else if (i==0)

  {

  dp[i][k]=dp[i][k - 1]矩阵[I][k];

  }

  其他

  {

  DP[I][k]=matrix[I][k]STD:min(DP[I-1][k],DP[I][k-1]);

  }

  }

  }

  返回DP[m-1][n-1];

  }

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

相关文章阅读

  • office2010激活密钥大全 怎么永久激活office2010
  • project2010产品密钥免费_project2010激活密钥永久激活码
  • c语言调用退出函数 c语言退出整个程序怎么写
  • c语言中怎么给函数初始化 c语言的初始化语句
  • c语言编写函数计算平均值 c语言求平均函数
  • chatgpt是什么?为什么这么火?
  • ChatGPT为什么注册不了?OpenAI ChatGPT的账号哪里可以注册?
  • OpenAI ChatGPT怎么注册账号?ChatGPT账号注册教程
  • chatgpt什么意思,什么是ChatGPT ?
  • CAD中怎么复制图形标注尺寸不变,CAD中怎么复制图形线性不变
  • cad中怎么创建并使用脚本文件,cad怎么运行脚本
  • cad中快速计算器的功能,cad怎么快速计算
  • cad中快速修改单位的方法有哪些,cad中快速修改单位的方法是
  • cad中心点画椭圆怎么做,cad轴测图怎么画椭圆
  • CAD中常用的快捷键,cad各种快捷键的用法
  • 留言与评论(共有 条评论)
       
    验证码: