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];
    }
};
相关推荐
KIDAKN1 小时前
JavaEE->多线程2
java·算法·java-ee
uwvwko2 小时前
数据结构学习——树的储存结构
数据库·学习·算法·
森焱森2 小时前
基于GD32F4XX串口环形缓冲区,北斗2.1协议,RD模块数据解析代码
c语言·单片机·算法·架构
秋风&萧瑟2 小时前
【C++】C++枚举、const、static的用法
c++·算法
玉~你还好吗2 小时前
【LeetCode#第228题】汇总区间(简单题)
算法·leetcode
_周游2 小时前
【数据结构】_二叉树部分特征统计
数据结构·算法
零点BUG2 小时前
推荐系统召回机制全景指南:从经典算法到工业级实践
算法
双叶8363 小时前
(C++)素数的判断(C++教学)(C语言)
c语言·开发语言·数据结构·c++·算法
Alfred king3 小时前
面试150 除自身以外数组的乘积
leetcode·面试·职场和发展
风靡晚4 小时前
汽车毫米波雷达增强感知:基于相干扩展和高级 IAA 的超分辨率距离和角度估计.
算法·汽车·信息与通信·信号处理·fmcw