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];
    }
};
相关推荐
小葡萄20252 小时前
VSCode 刷 LeetCode 算法题配置教程
vscode·算法·leetcode
努力冲冲5 小时前
常用排序算法
java·算法·排序算法
夜斗小神社8 小时前
【LeetCode 热题 100】(六)矩阵
算法·leetcode·矩阵
天地一流殇9 小时前
SimBA算法实现过程
深度学习·算法·对抗攻击·黑盒
2501_924730619 小时前
智慧城管复杂人流场景下识别准确率↑32%:陌讯多模态感知引擎实战解析
大数据·人工智能·算法·计算机视觉·目标跟踪·视觉检测·边缘计算
weixin_307779139 小时前
C++实现MATLAB矩阵计算程序
开发语言·c++·算法·matlab·矩阵
学不动CV了9 小时前
FreeRTOS入门知识(初识RTOS任务调度)(三)
c语言·arm开发·stm32·单片机·物联网·算法·51单片机
Kingfar_110 小时前
智能移动终端导航APP用户体验研究案例分享
人工智能·算法·人机交互·ux·用户界面·用户体验
dlraba80210 小时前
机器学习-----SVM(支持向量机)算法简介
算法·机器学习·支持向量机
_poplar_10 小时前
09 【C++ 初阶】C/C++内存管理
c语言·开发语言·数据结构·c++·git·算法·stl