leetcode 62 不同路径

一、题目描述

二、解题思路

(1)解法一:深度优先搜索

1>函数功能:dfs函数用于从(i,j)位置开始,寻找到达终点(m-1,n-1)的路径条数;

2>递归出口:当i==m-1&&j==n-1时,表示找到了一条路径,ret++,然后return;

3>函数体:按照下、右的顺序进行探索,如果(x,y)未越界就对(x,y)位置递归调用dfs函数。

(2)解法二:直接递归

由于只能向下和向右走,所以只有从上面块和左边块才能到达现在所在的块,uniquePaths(i,j)表示到达(i,j)位置的路径的数量,则uniquePaths(i,j)=uniquePaths(i-1,j)+uniquePaths(i,j-1)。

(3)解法三:记忆化搜索

由于解法二在计算的过程中存在大量的重复计算,所以可以采用记忆化搜索的方法,把计算的结果记录下来,避免重复计算。

(4)解法四:动态规划

dp[i][j]的值表示从(0,0)到终点(i,j)的路径的条数,dp[i][j]=dp[i-1][j]+dp[i][j-1]

三、代码实现

解法一:深度优先搜索(超时)

cpp 复制代码
class Solution {
    int ret=0;
public:
    int uniquePaths(int m, int n) {
        dfs(0,0,m,n);
        return ret;
    }

    int dx[2]={1,0};
    int dy[2]={0,1};

    void dfs(int i,int j,int m,int n){
        //递归出口
        if(i==m-1&&j==n-1){
            ret++;
            return ;
        }
        
        for(int k=0;k!=2;k++){
            int x=i+dx[k];
            int y=j+dy[k];
            if(x>=0&&x<m&&y>=0&&y<n)
                dfs(x,y,m,n);
        }
    }
};

解法二:直接递归(超时)

cpp 复制代码
class Solution {
public:
    int uniquePaths(int m, int n) {
        //边界处理
        if(m==1||n==1) return 1;
        return uniquePaths(m-1,n)+uniquePaths(m,n-1);
    }
};

解法三:记忆化搜索

cpp 复制代码
class Solution {
    vector<vector<int>> memo;
public:
    int uniquePaths(int m, int n) {
        //边界处理
        if(m==1||n==1) return 1;

        memo.resize(m+1,vector(n+1,-1));
        for(int i=0;i<=n;i++) memo[0][i]=1;
        for(int j=0;j<=m;j++) memo[j][0]=1;

        return dfs(m-1,n-1);
    }

    int dfs(int m,int n){
        //查找备忘录
        if(memo[m][n]!=-1)  return memo[m][n];
        else{
            memo[m][n]=dfs(m-1,n)+dfs(m,n-1);
            return memo[m][n];
        }
    }
};

解法四:动态规划

cpp 复制代码
class Solution {
public:
    int uniquePaths(int m, int n) {
        vector<vector<int>> dp(m,vector(n,-1));
        //填写dp数组
        for(int i=0;i!=m;i++) dp[i][0]=1;
        for(int j=0;j!=n;j++) dp[0][j]=1;
        for(int row=1;row!=m;row++)
            for(int col=1;col!=n;col++)
                dp[row][col]=dp[row-1][col]+dp[row][col-1];
        return dp[m-1][n-1];
    }
};
相关推荐
超级码力66635 分钟前
【Latex文件架构】Latex文件架构模板
算法·数学建模·信息可视化
穿条秋裤到处跑1 小时前
每日一道leetcode(2026.04.29):二维网格图中探测环
算法·leetcode·职场和发展
Merlos_wind1 小时前
HashMap详解
算法·哈希算法·散列表
汉克老师2 小时前
GESP2025年3月认证C++五级( 第三部分编程题(1、平均分配))
c++·算法·贪心算法·排序·gesp5级·gesp五级
Yzzz-F4 小时前
Problem - 2205D - Codeforces
算法
智者知已应修善业5 小时前
【51单片机2个按键控制流水灯运行与暂停】2023-9-6
c++·经验分享·笔记·算法·51单片机
Halo_tjn5 小时前
Java Set集合相关知识点
java·开发语言·算法
生成论实验室5 小时前
《事件关系阴阳博弈动力学:识势应势之道》第四篇:降U动力学——认知确定度的自驱演化
人工智能·科技·神经网络·算法·架构
AI科技星6 小时前
全域数学·72分册:场计算机卷【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
云泽8086 小时前
C++11 核心特性全解:列表初始化、右值引用与移动语义实战
开发语言·c++