java算法day39 | 动态规划part02 ● 62.不同路径 ● 63. 不同路径 II

62.不同路径




思路: 本题非常巧妙。

第一步:定义一个dp数组存储到达每个位置的路径数。

第二步:每个位置的路径数=它左面位置的路径数+上面位置的路径数。

第三步:不好想的是如何初始化数组。

既然只能向下或向右走,可推出最上面一排和最左面一列的所有位置上的路径只有一条。

第四步:遍历顺序是从右上角到左下角。

第五步:模拟一遍。

java 复制代码
class Solution {
    public int uniquePaths(int m, int n) {
        int[][] dp=new int[m][n];//第一步:定义一个数组,表示到达该位置的路径数
        //3、初始化数组
        if(m==1 || n==1) return 1;
        for(int i=1;i<m;i++){
            dp[i][0]=1;
        }
        for(int i=1;i<n;i++){
            dp[0][i]=1;
        }
        for(int i=1;i<m;i++){//2、遍历顺序
            for(int j=1;j<n;j++){
                dp[i][j]=dp[i-1][j]+dp[i][j-1];//4、递推公式
            }
        }
        return dp[m-1][n-1];//5、举例推导

    }
}

时间复杂度:O(m × n)

空间复杂度:O(m × n)

63. 不同路径 II



思路: 和上一题思路一样,只是遇到障碍物就将当前位置设为零。注意:当在初始化时遇到障碍物,则将之后的位置都设为0,因为根本无法到达这些位置。

java 复制代码
class Solution {
    public int uniquePathsWithObstacles(int[][] obstacleGrid) {
        int m=obstacleGrid.length;
        int n=obstacleGrid[0].length;
        int[][] dp=new int[m][n];
        for(int i=0;i<m;i++){
            if(obstacleGrid[i][0]==0) dp[i][0]=1;
            else break;
        }
        for(int i=0;i<n;i++){
            if(obstacleGrid[0][i]==0) dp[0][i]=1;
            else break;
        }

        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];
                }else{
                    dp[i][j]=0;
                }
            }
        }
        return dp[m-1][n-1];
    }
}

时间复杂度:O(m × n)

空间复杂度:O(m × n)

相关推荐
程序员-King.3 小时前
day158—回溯—全排列(LeetCode-46)
算法·leetcode·深度优先·回溯·递归
Leo July3 小时前
【Java】Spring Security 6.x 全解析:从基础认证到企业级权限架构
java·spring·架构
星火开发设计4 小时前
C++ 数组:一维数组的定义、遍历与常见操作
java·开发语言·数据结构·c++·学习·数组·知识
码道功成4 小时前
Pycham及IntelliJ Idea常用插件
java·ide·intellij-idea
月挽清风4 小时前
代码随想录第七天:
数据结构·c++·算法
小O的算法实验室4 小时前
2026年AEI SCI1区TOP,基于改进 IRRT*-D* 算法的森林火灾救援场景下直升机轨迹规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
消失的旧时光-19434 小时前
第四篇(实战): 订单表索引设计实战:从慢 SQL 到毫秒级
java·数据库·sql
それども4 小时前
@ModelAttribute vs @RequestBody
java
小郭团队5 小时前
2_1_七段式SVPWM (经典算法)算法理论与 MATLAB 实现详解
嵌入式硬件·算法·硬件架构·arm·dsp开发
充值修改昵称5 小时前
数据结构基础:从二叉树到多叉树数据结构进阶
数据结构·python·算法