Leetcode—62.不同路径【中等】

2023每日刷题(七十二)

Leetcode—62.不同路径

Leetcode—62.不同路径【中等】_第1张图片

超时dfs代码

class Solution {
public:
    int uniquePaths(int m, int n) {
        int starti = 1, startj = 1;
        int ans = 0;
        function<void(int, int)> dfs = [&](int i, int j) {
            if(i == m && j == n) {
                ans++;
                return;
            }
            if(i > m || j > n) {
                return;
            }
            dfs(i + 1, j);
            dfs(i, j + 1);
        };
        dfs(1, 1);
        return ans;
    }
};

运行结果

Leetcode—62.不同路径【中等】_第2张图片

动态规划C++实现代码

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

运行结果

Leetcode—62.不同路径【中等】_第3张图片

之后我会持续更新,如果喜欢我的文章,请记得一键三连哦,点赞关注收藏,你的每一个赞每一份关注每一次收藏都将是我前进路上的无限动力 !!!↖(▔▽▔)↗感谢支持!

你可能感兴趣的:(LeetCode刷题,leetcode,深度优先,算法,c++,经验分享,动态规划)