【算法五十】62. 不同路径

62. 不同路径

动态规划(二维数组):

java 复制代码
class Solution {
    public int uniquePaths(int m, int n) {
        //子问题:走到目标的左边以及上边的方法和
        //从左上角走到dp[i][j]有多少种路径
        //状态转移方程:dp[i][j] = dp[i-1][j] + dp[i][j-1]
        //从小到大

        int[][] dp = new int[m][n];
        dp[0][0] = 1;
        for(int i = 0;i<m;i++){
            for(int j = 0;j<n;j++){
                if(i ==0 && j==0){
                    continue;
                }
                dp[i][j] = (i>0 ? dp[i-1][j]:0) + (j>0 ? dp[i][j-1]:0);
            }
        }
        return dp[m-1][n-1];
    }
}

时间复杂度:O(M*N)

空间复杂度:O(M*N)

动态规划(一维数组):

java 复制代码
class Solution {
    public int uniquePaths(int m, int n) {
        int[] dp = new int[n];
        //第一行只有1
        for(int i = 0;i<n;i++){
            dp[i] = 1;
        }

        //接着换行处理
        for(int i = 1;i<m;i++){
            for(int j = 1;j<n;j++){
                dp[j] = dp[j] + dp[j-1];
            }
        }
        return dp[n-1];
    }
}

时间复杂度:O(M*N)

空间复杂度:O(N)

优化思路:就是将二维的m转化为for循环里的i,按层去处理,因为dp[i][j]只和自己左边还有上面的数值有关

相关推荐
玖釉-3 小时前
下一个排列:从字典序到原地算法的完整推导
数据结构·c++·windows·算法
影寂ldy3 小时前
C#一维数组
算法
过期动态4 小时前
【LeetCode 热题 100】移动零
java·数据结构·算法·leetcode·职场和发展·rabbitmq
计算机安禾4 小时前
【算法分析与设计】第10篇:下界理论与NP完全性初步
大数据·人工智能·算法
水木流年追梦5 小时前
大模型入门-大模型分布式训练2
开发语言·分布式·python·算法·正则表达式·prompt
sali-tec5 小时前
C# 基于OpenCv的视觉工作流-章78-KRT测量
图像处理·人工智能·数码相机·opencv·算法·计算机视觉
菜菜的顾清寒6 小时前
力扣HOT100(32)二叉树的中序遍历
数据结构·算法·leetcode
x2c6 小时前
数据结构:线性表中链表的建立和基本操作(C)
算法