动态规划-62.不同路径-力扣(LeetCode)

一、题目解析

机器人只能向下或向左,要从Start位置到Finish位置。

二、算法原理

1.状态表示

我们要求到Finish位置一共有多少种方法,记Finish为[i,j],此时dp[i,j]表示:到[i,j]位置时,一共有多少种方法,满足我们的需求。

2.状态转移方程

根据最近一步划分问题

3.初始化

开辟二维数组时,需要开辟(m+1)*(n+1)大小的空间,dp[0][0~n]和dp[0~m][0]用于初始化,其余dp[1][1]~dp[m][n]用于记录到达该位置的总方法数。

4.填表顺序

每行从左往右填写,每一列从上往下填写

5.返回值

由于Finish位置是[i][j],所以结果返回dp[m][n]

可以先根据上面原理去尝试编写代码,链接:62. 不同路径 - 力扣(LeetCode)

三、代码示例

cpp 复制代码
class Solution {
public:
    int uniquePaths(int m, int n) {
        vector<vector<int>> dp(m+1,vector<int>(n+1));
        dp[0][1] = 1;
        for(int i = 0;i<=m;i++) dp[i][0] = 0;
        for(int j = 2;j<=n;j++) dp[0][j] = 0;
        for(int i = 1;i<=m;i++)
        {
            for(int j =1;j<=n;j++)
            {
                dp[i][j] = dp[i][j-1]+dp[i-1][j];
            }
        }

        return dp[m][n];
    }
};

看到最后,如果对您有所帮助还请点赞和收藏,我们下期再见!

相关推荐
一只小小的芙厨9 小时前
AT_tkppc3_d 巨大チェスボード 题解
c++·题解
我在人间贩卖青春9 小时前
C++之继承与派生类的关系
c++·向上造型·向下造型
Trouvaille ~9 小时前
【Linux】应用层协议设计实战(二):Jsoncpp序列化与完整实现
linux·运维·服务器·网络·c++·json·应用层
_OP_CHEN9 小时前
【算法基础篇】(五十七)线性代数之矩阵乘法从入门到实战:手撕模板 + 真题详解
线性代数·算法·矩阵·蓝桥杯·c/c++·矩阵乘法·acm/icpc
天天爱吃肉82189 小时前
【跨界封神|周杰伦×王传福(陶晶莹主持):音乐创作与新能源NVH测试,底层逻辑竟完全同源!(新人必看入行指南)】
python·嵌入式硬件·算法·汽车
im_AMBER9 小时前
Leetcode 114 链表中的下一个更大节点 | 删除排序链表中的重复元素 II
算法·leetcode
EmbedLinX9 小时前
嵌入式之协议解析
linux·网络·c++·笔记·学习
xhbaitxl10 小时前
算法学习day38-动态规划
学习·算法·动态规划
多恩Stone10 小时前
【3D AICG 系列-6】OmniPart 训练流程梳理
人工智能·pytorch·算法·3d·aigc
wangjialelele10 小时前
Linux中的进程管理
java·linux·服务器·c语言·c++·个人开发