leetcode hot100刷题日记——21.不同路径

和20题一样的思路link

题解:

cpp 复制代码
class Solution {
public:
    int dfs(int i,int j,vector<vector<int>>&memo){
        //超过了边界,return 0
        if(i<0||j<0){
            return 0;
        }
        //从(0,0)到(0,0)只有一条路
        if(i==0&&j==0){
            return 1;
        }
        int &res=memo[i][j];//看之前有没有走过
        if(res){
            return res;//如果走过
        }
        return res=dfs(i-1,j,memo)+dfs(i,j-1,memo);
    }
    int uniquePaths(int m, int n) {
        vector memo(m,vector<int>(n));//用m行n列的数组存位置状态
        return dfs(m-1,n-1,memo);
    }
};
cpp 复制代码
class Solution {
public:
    int uniquePaths(int m, int n) {
        //dp[i][j]=dp[i-1][j]+dp[i][j-1]
        //即:dp[i+1][j+1]=dp[i][j+1]+dp[i+1][j]
        vector dp(m+1,vector<int>(n+1));
        for(int i=0;i<m;i++){
            for(int j=0;j<n;j++){
                if(i==0&&j==0){
                    dp[1][1]=1;//其实看成左上角顶点是(1,1),只有1种方法走到
                }else{
                    dp[i+1][j+1]=dp[i][j+1]+dp[i+1][j];//假设i=0,j=1,dp[1][2]=dp[0][2]+dp[1][1]
                    //这个时候其实是要走到顶点处下面一格,那么很容易知道dp[0][j]和dp[i][0]都必须是0
                    //因为超过边界了,我们在初始化dp数组的时候,dp数组全是0,所以已经包含了以上
                }
            }
        }
        return dp[m][n];
    }
};
相关推荐
岁忧1 小时前
(nice!!!)(LeetCode 面试经典 150 题 ) 30. 串联所有单词的子串 (哈希表+字符串+滑动窗口)
java·c++·leetcode·面试·go·散列表
艾莉丝努力练剑2 小时前
【数据结构与算法】数据结构初阶:详解顺序表和链表(四)——单链表(下)
c语言·开发语言·数据结构·学习·算法·链表
yngsqq3 小时前
移动碰撞法 ——套料排版算法——CAD c#
算法
秋说4 小时前
【PTA数据结构 | C语言版】根据层序序列重构二叉树
c语言·数据结构·算法
秋说5 小时前
【PTA数据结构 | C语言版】前序遍历二叉树
c语言·数据结构·算法
会唱歌的小黄李6 小时前
【算法】贪心算法:最大数C++
c++·算法·贪心算法
NuyoahC6 小时前
笔试——Day8
c++·算法·笔试
墨染点香6 小时前
LeetCode Hot100 【1.两数之和、2.两数相加、3.无重复字符的最长子串】
算法·leetcode·职场和发展
秋说7 小时前
【PTA数据结构 | C语言版】二叉树层序序列化
c语言·数据结构·算法
地平线开发者7 小时前
开发者说|Aux-Think:为什么测试时推理反而让机器人「误入歧途」?
算法·自动驾驶