力扣62不同路径总数,动态规划 一招制敌

0. 题目

一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为“Start” )。

机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为“Finish”)。

问总共有多少条不同的路径?

1. 先来看效果,还可以吧

执行用时 :1 ms, 在所有 Java 提交中击败了93.69%的用户
内存消耗 :33 MB, 在所有 Java 提交中击败了14.41%的用户

2. 怎么做,其实就和力扣的64题差不多,动态规划,倒着做

力扣64题解: 传送门

简单的画了一个图 在这里插入图片描述
M是行,N是列
从右下角开始,我们认为是dp[0][0] 所以最下面一行也就是第一行dp[1][X]数值都是1,同理
最右边一列也就是第一列,dp[X][0]数值也是1
dp[m][n]=dp[m][n-1]+dp[n][m-1]
比如图上的A B CD
A=1+1=2
B=A+1=3
C=3+B=6
D=5+1=6

3. 完整代码

public static int uniquePaths(int m, int n) {

  int dp[][] = new int[m][n];
  dp[0][0] = 1;
  for (int i = 1; i < m; i++) {
      dp[i][0] = 1;
  }
  for (int j = 1; j < n; j++) {
      dp[0][j] = 1;
  }
  for (int i = 1; i < m; i++) {
      for (int j = 1; j < n; j++) {
          dp[i][j] = dp[i][j - 1] + dp[i - 1][j];
      }
  }
  return dp[m - 1][n - 1];

}

代码最后为啥都是M和N都要减去1,因为for循环里面是自增的,在最后即使是不满足情况的条件下还是都加了1的,所以都要减去

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值