当前位置:   article > 正文

给定一个矩阵m,从左上角开始每次只能向右走或者向下走,最后达到右下角的位置_给定一个m行n列的矩阵,从左上角开始每次只能向右或者向下移动,最后到达右下角的位

给定一个m行n列的矩阵,从左上角开始每次只能向右或者向下移动,最后到达右下角的位
/*
 * 给定一个矩阵m,从左上角开始每次只能向右走或者向下走,最后达到右下角的位置,
 * 路径中所有数字累加起来就是路径和,返回所有路径的最小路径和,如果给定的m如下,那么路径1,3,1,0,6,1,0就是最小路径和,返回12.
1 3 5 9
8 1 3 4
5 0 6 1
8 8 4 0
分析: 对于这个题目,假设m是m行n列的矩阵,那么我们用dp[m][n]来抽象这个问题,
dp[]i]表示的是从原点到i,j位置的最短路径和。我们首先计算第一行和第一列,直接累加即可,
那么对于其他位置,要么是从它左边的位置达到,要么是从上边的位置达到,我们取左边和上边的较小值,然后加上当前的路径值
*/
/*
 得到的公式如下
 m(0,0)            if(i==0 && j==0)
 dp(i,j-1)+m(i,j)  if(i==0)
 dp(i-1,j)+m(i,j)  if(j==0)
 min{dp(i,j-1)+m(i,j),dp(i-1,j)+m(i,j)}  else

 */


  1. public class MaritixMin {
  2. public static int minDis(int[][] m) {
  3. int [][] dp = new int[4+1][4+1];
  4. dp[0][0] = m[0][0];
  5. for (int i = 1; i < m.length; i++) {
  6. for (int j = 1; j < m[0].length; j++) {
  7. if(i==1) {
  8. dp[i][j] = dp[i][j-1]+m[i][j];
  9. }else if(j==1) {
  10. dp[i][j] = dp[i-1][j] +m[i][j];
  11. }else {
  12. int temp1 = dp[i][j-1]+m[i][j];
  13. int temp2 = dp[i-1][j]+m[i][j];
  14. int min = temp1<temp2?temp1:temp2;
  15. dp[i][j] = min;
  16. }
  17. }
  18. }
  19. return dp[m[0].length-1][m.length-1];
  20. }
  21. public static void main(String[] args) {
  22. int[][] martix = {{0,0,0,0,0},
  23. {0,1,3,5,9},
  24. {0,8,1,3,5},
  25. {0,5,0,6,1},
  26. {0,8,8,4,0}};
  27. System.out.println("最右下的最短路径为:"+minDis(martix));
  28. }
  29. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/2023面试高手/article/detail/484252
推荐阅读
相关标签
  

闽ICP备14008679号