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

62.不同路径

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

java 复制代码
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)

java 复制代码
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];

    }
}
相关推荐
2301_80421541几秒前
自定义异常类设计
开发语言·c++·算法
暮冬-  Gentle°2 分钟前
C++代码依赖分析
开发语言·c++·算法
2301_763891955 分钟前
泛型编程与STL设计思想
开发语言·c++·算法
j_xxx404_7 分钟前
蓝桥杯基础--进制转换
开发语言·数据结构·c++·算法·职场和发展·蓝桥杯
阿Y加油吧16 分钟前
力扣链表高频题:两两交换节点 + K个一组翻转链表(保姆级思路+满分代码)
算法·leetcode·链表
Boop_wu19 分钟前
[Java 算法] 动态规划2
算法·leetcode·动态规划
yugi98783825 分钟前
非支配排序遗传算法NSGA-III详解与MATLAB实现
算法
ballball~~25 分钟前
ISP-Tone Mapping
图像处理·算法·isp
米粒126 分钟前
力扣算法刷题 Day22
算法·leetcode·职场和发展
科德航空的张先生26 分钟前
飞行错觉(空间定向障碍)地面模拟训练系统
人工智能·算法