Leetcode刷题详解——不同路径

1. 题目链接:62. 不同路径

2. 题目描述:

一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 “Start” )。

机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 “Finish” )。

问总共有多少条不同的路径?

示例 1:

img

输入:m = 3, n = 7
输出:28

示例 2:

输入:m = 3, n = 2
输出:3
解释:
从左上角开始,总共有 3 条路径可以到达右下角。
1. 向右 -> 向下 -> 向下
2. 向下 -> 向下 -> 向右
3. 向下 -> 向右 -> 向下

示例 3:

输入:m = 7, n = 3
输出:28

示例 4:

输入:m = 3, n = 3
输出:6

提示:

  • 1 <= m, n <= 100
  • 题目数据保证答案小于等于 2 * 109

解法1(暴力搜索):

由于复杂度太高会超时

算法思路:

  1. 递归含义:给dfs一个使命,给他一个下标,返回从[0,0]位置走到[i,j]位置一共有多少种方法

  2. 函数体:只要知道到达上面位置的方法数以及到达左边位置的方法数,然后累加起来即可

  3. 递归出口:当下标越界的时候返回0;当前位于起点的时候,返回1

请添加图片描述

C++算法代码:

class Solution {
public:int uniquePaths(int m, int n) {return dfs(m,n);}int dfs(int i,int j){if(i==0||j==0) return 0;if(i==1&&j==1) return 1;return dfs(i-1,j)+dfs(i,j-1);}
};

解法2(记忆化搜索):

算法思路:

  1. 加上一个备忘录
  2. 每次进入递归的时候,去备忘录看看
  3. 每次返回的时候,将结果加入到备忘录里面

请添加图片描述

C++算法代码:

class Solution {
public:int uniquePaths(int m, int n) {vector<vector<int>> memo(m+1, vector<int>(n+1)); // 创建一个二维数组memo,用于存储已经计算过的路径数return dfs(m, n, memo); // 调用深度优先搜索函数dfs,传入参数m、n和memo}int dfs(int i, int j, vector<vector<int>>& memo) {if (memo[i][j] != 0) { // 如果memo[i][j]不为0,说明已经计算过这个位置的路径数,直接返回memo[i][j]return memo[i][j];} if (i == 0 || j == 0) return 0; // 如果i或j为0,说明已经到达边界,无法继续前进,返回0if (i == 1 && j == 1) { // 如果i和j都为1,说明已经到达终点,返回1memo[i][j] = 1;return 1;}memo[i][j] = dfs(i - 1, j, memo) + dfs(i, j - 1, memo); // 递归计算从当前位置向上和向左移动的路径数之和,并将结果存储在memo[i][j]中return memo[i][j]; // 返回memo[i][j]作为结果}
};

解法3(动态规划):

算法思路:

  1. 函数含义->状态表示
  2. 函数体->状态转移方程
  3. 递归出口->初始化

请添加图片描述

C++算法代码:

class Solution {
public:int uniquePaths(int m, int n) {// 创建一个二维数组dp,大小为(m+1) x (n+1),用于存储每个位置的路径数vector<vector<int>> dp(m + 1, vector<int>(n + 1));// 初始化起点的路径数为1dp[1][1] = 1;// 遍历二维数组,计算每个位置的路径数for (int i = 1; i <= m; i++) {for (int j = 1; j <= n; j++) {// 如果当前位置是起点,跳过if (i == 1 && j == 1) continue;// 当前位置的路径数等于上方位置的路径数加上左方位置的路径数dp[i][j] = dp[i - 1][j] + dp[i][j - 1];}}// 返回终点的路径数return dp[m][n];}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/189581.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

23111703[含文档+PPT+源码等]计算机毕业设计javaweb商城项目全套电商购物系统

文章目录 **软件开发环境及开发工具&#xff1a;****项目功能介绍&#xff1a;****论文截图&#xff1a;****实现****代码片段&#xff1a;** 编程技术交流、源码分享、模板分享、网课教程 &#x1f427;裙&#xff1a;776871563 软件开发环境及开发工具&#xff1a; 前端使用…

ubuntu中/etc/rc.local和/etc/init.d/rc.local的区别是什么

在早期版本的Ubuntu中&#xff0c;通常会使用 /etc/rc.local 或 /etc/init.d/rc.local 文件执行在系统启动时需要运行的自定义脚本或命令。然而&#xff0c;随着Ubuntu的版本升级&#xff0c;这两者的使用方式有了一些变化。 /etc/rc.local&#xff1a; 功能&#xff1a; /etc/…

【工作记录】springboot应用实现license认证

前言 License授权是一种常见的商业模式&#xff0c;一般用于在客户端部署项目后进行使用人员或功能限制&#xff0c;也常用于软件的试用场景。 主要实现思路就是在服务端生成密钥对及证书&#xff0c;在客户端启动或访问过程中进行验证。 本文实现的是通过IP地址、MAC地址、…

Cascade-MVSNet论文笔记

Cascade-MVSNet论文笔记 摘要1 立体匹配&#xff08;Stereo Matching&#xff09;2 多视图立体视觉&#xff08;Multi-View Stereo&#xff09;3 立体视觉和立体视觉的高分辨率输出4 代价体表达方式&#xff08;Cost volume Formulation&#xff09;4.1 多视图立体视觉的3D代价…

Pytorch torch.norm函数详解用法

torch.norm参数定义 torch版本1.6 def norm(input, p"fro", dimNone, keepdimFalse, outNone, dtypeNone)input input (Tensor): the input tensor 输入为tensorp p (int, float, inf, -inf, fro, nuc, optional): the order of norm. Default: froThe following …

深度优化数据库性能:Linux 内核参数调整解析

点击上方蓝字关注我 数据库服务器性能的优化是每个IT团队关注的焦点之一。除了数据库引擎的优化之外&#xff0c;合理调整操作系统的内核参数也是提高数据库性能的关键。本文将解析一些常见的 Linux 内核参数&#xff0c;以及它们在数据库服务器优化中的作用和建议的值。 1. 参…

FastJsonAPI

maven项目 pom.xml <dependencies><dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>2.0.26</version></dependency><dependency><groupId>junit</groupId>&l…

Find My数据线|苹果Find My技术与数据线结合,智能防丢,全球定位

数据线是用来连接移动设备和电脑的&#xff0c;来达到数据传递或通信目的。通俗点说&#xff0c;就是连接电脑与移动设备用来传送视频、铃声、图片等文件的通路工具。现在&#xff0c;随着电子行业日新月异的发展&#xff0c;数据线已经成为了我们生活中不可或缺的部分&#xf…

竞赛选题 深度学习驾驶行为状态检测系统(疲劳 抽烟 喝水 玩手机) - opencv python

文章目录 1 前言1 课题背景2 相关技术2.1 Dlib人脸识别库2.2 疲劳检测算法2.3 YOLOV5算法 3 效果展示3.1 眨眼3.2 打哈欠3.3 使用手机检测3.4 抽烟检测3.5 喝水检测 4 最后 1 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; 基于深度学习的驾…

《C语言程序设计 谭浩强 第4版》:使用结构体类型处理组合数据 - 用户自定义数据类型

一、定义和使用结构体变量 1、自己建立结构体类型 C 语言允许用户自己定义由不同类型数据组成的组合型的数据结构&#xff0c;它称为 结构体 一般形式&#xff1a; struct 结构体名{成员表列; } 结构体类型的名字是由一个关键字 struct 和结构体名二者组合而成的 结构…

【mysql】2006 - Server has gone away

执行了一组插入语句 提示&#xff1a;2006 - Server has gone away&#xff1b; 2006-服务器已经消失&#xff1b; 消失去哪里了&#xff0c;被黑洞吞没了吗&#xff1f;&#xff01;&#xff01;&#xff01; 网络问题 网络不稳定&#xff1f;断网了&#xff1f;检查网络连…

可逆矩阵的性质

如果矩阵A可逆&#xff0c;那么它的逆矩阵也可逆&#xff0c;并且如果矩阵A可逆&#xff0c;假设是一个不为0的数&#xff0c;那么也可逆&#xff0c;并且如果矩阵A和都可逆&#xff0c;而且它们的阶数也相同&#xff0c;那么它们的乘积也是可逆的&#xff0c;并且如果矩阵A可逆…