算法训练营Day39(动态规划)

 62.不同路径 

62. 不同路径 - 力扣(LeetCode)

class Solution {
    public int uniquePaths(int m, int n) {
        //1dp数组  m n代表位置,dp[m][n]代表到达这里的途径个数
        int [][] dp = new int[m][n];
        //3初始化
        for(int i = 0;i<n;i++){
            dp[0][i] = 1;
        }
        for(int j = 0;j<m;j++){
            dp[j][0] = 1;
        }
        //4遍历顺序
        for(int i = 1;i<m;i++){
            for(int j = 1;j<n;j++){
                //2递推公式
                dp[i][j] = dp[i-1][j]+dp[i][j-1]; 
            }
        }
        return dp[m-1][n-1];
    }
}

 63. 不同路径 II 

63. 不同路径 II - 力扣(LeetCode)

class Solution {
    public int uniquePathsWithObstacles(int[][] obstacleGrid) {
        int m = obstacleGrid.length;
        int n = obstacleGrid[0].length;
        int [][] dp = new int [m][n];
        //如果在起点或终点出现了障碍,直接返回0
        if (obstacleGrid[m - 1][n - 1] == 1 || obstacleGrid[0][0] == 1) {
            return 0;
        }
    
        for(int i = 0;i<n;i++){
            if(obstacleGrid[0][i]==1){
                break;
            }
            dp[0][i]=1;
        }
        for(int j=0;j<m;j++){
            if(obstacleGrid[j][0]==1) break;
            dp[j][0] = 1;
        }

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

    }
}

相关推荐

  1. 算法训练Day39(动态规划

    2024-01-10 21:44:01       57 阅读
  2. 算法训练Day40(动态规划

    2024-01-10 21:44:01       64 阅读
  3. 代码随想录算法训练 Day39 动态规划2

    2024-01-10 21:44:01       35 阅读
  4. 算法训练Day43(动态规划5)

    2024-01-10 21:44:01       64 阅读
  5. 算法训练Day48(动态规划9)

    2024-01-10 21:44:01       56 阅读
  6. 算法训练Day49(动态规划10)

    2024-01-10 21:44:01       58 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-10 21:44:01       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-10 21:44:01       100 阅读
  3. 在Django里面运行非项目文件

    2024-01-10 21:44:01       82 阅读
  4. Python语言-面向对象

    2024-01-10 21:44:01       91 阅读

热门阅读

  1. Edge浏览器开启/关闭侧栏和找回Copilot&Bing按钮

    2024-01-10 21:44:01       115 阅读
  2. Ansible刚安装完后执行报错

    2024-01-10 21:44:01       51 阅读
  3. 力扣labuladong——一刷day89

    2024-01-10 21:44:01       53 阅读
  4. gradient_checkpointing

    2024-01-10 21:44:01       50 阅读
  5. IC设计的前端和后端是如何区分的?

    2024-01-10 21:44:01       63 阅读
  6. 关于MySQL源码的学习 这里是一些建议

    2024-01-10 21:44:01       52 阅读
  7. python工具-udp-tcp-client-server-demo

    2024-01-10 21:44:01       61 阅读
  8. 【React】常见疑问的整理

    2024-01-10 21:44:01       59 阅读