Leetcode62. 不同路径(HOT100)

链接

我的代码:

cpp 复制代码
class Solution {
public:
    int uniquePaths(int m, int n) {
        if(m<=1||n<=1)return 1;
        vector<vector<int>> dp(m,vector<int>(n));
        for(int i = 0;i<m;i++){
            for(int j = 0;j<n;j++){
                if(!i&&!j)dp[i][j] = 0;
                else if(!i||!j)dp[i][j] = 1;
                else dp[i][j] = dp[i-1][j]+dp[i][j-1];
            }
        }
        return dp[m-1][n-1];
    }
};

空间优化为O(N):

cpp 复制代码
class Solution {
public:
    int uniquePaths(int m, int n) {
        vector<int> f(n,1);
        for(int i = 1;i<m;i++){
            for(int j = 1;j<n;j++){
                f[j] +=f[j-1];
            }
        }
        return f[n-1];
    }
};


//空间O(N),时间O(m*n)
// 动态规划数组f:
// 使用一维数组 f 来存储每一列的路径数。数组大小为 n,表示当前行的路径数。
// 初始化 f 为 1,表示从起点 (0, 0) 到达任意第一行或第一列的路径数都是 1(因为只能直走)。
// 循环更新路径数:
// 外层循环 for (int i = 1; i < m; i++) 遍历每一行,从第二行开始,因为第一行已经初始化。
// 内层循环 for (int j = 1; j < n; j++) 遍历每一列,从第二列开始。
// f[j] = f[j] + f[j - 1]; 这行代码的核心逻辑:
// f[j] 表示到达位置 (i, j) 的路径数。
// 这个值是由上方位置 (i-1, j) 的路径数(即 f[j])和左侧位置 (i, j-1) 的路径数(即 f[j-1])相加得来的。
// 因此,f[j] 更新为当前格子路径数的总和。
相关推荐
虫师c1 分钟前
List vs Set:深入剖析Java两大集合的核心区别与实战应用
java·数据结构·list·set·java集合
沧澜sincerely2 分钟前
BFS & 图论【各种题型+对应LeetCode习题练习】
leetcode·图论·广度优先
ChoSeitaku3 分钟前
线代强化NO6|矩阵|例题|小结
算法·机器学习·矩阵
Neil今天也要学习8 分钟前
永磁同步电机无速度算法--基于一阶线性状态观测器的反电动势观测器
算法
橘颂TA11 分钟前
【剑斩OFFER】算法的暴力美学——寻找峰值
数据结构·算法·力扣·c/c++
陈陈爱java11 分钟前
秋招八股算法常见
数据结构·算法
不穿格子的程序员14 分钟前
从零开始写算法——二分-寻找旋转排序数组中的最小值
数据结构·算法·leetcode·二分查找
小白程序员成长日记15 分钟前
2025.11.13 力扣每日一题
算法·leetcode·职场和发展
二川bro16 分钟前
第33节:程序化生成与无限地形算法
前端·算法·3d·threejs
Learn Beyond Limits1 小时前
Regression vs. Classification|回归vs分类
人工智能·python·算法·ai·分类·数据挖掘·回归