当前位置: 首页 > news >正文

04动态规划

62.不同路径(来源:代码随想录)

一个机器人位于一个 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

Code

class Solution {
private:int dfs(int i, int j, int m, int n) {if (i > m || j > n) return 0; // 越界了if (i == m && j == n) return 1; // 找到一种方法,相当于找到了叶子节点return dfs(i + 1, j, m, n) + dfs(i, j + 1, m, n);}
public:int uniquePaths(int m, int n) {return dfs(1, 1, m, n);}
};

  • 可以用深搜,但是会超时(考试场景中可用dfs拿部分分,dfs暴力解法)

  • 这道题目,刚一看最直观的想法就是用图论里的深搜,来枚举出来有多少种路径。

    注意题目中说机器人每次只能向下或者向右移动一步,那么其实机器人走过的路径可以抽象为一棵二叉树,而叶子节点就是终点!

    如图举例:1775036957536

此时问题就可以转化为求二叉树叶子节点的个数,代码如上

  • 大家如果提交了代码就会发现超时了!

    来分析一下时间复杂度,这个深搜的算法,其实就是要遍历整个二叉树。

    这棵树的深度其实就是m+n-1(深度按从1开始计算)。

    那二叉树的节点个数就是 2^(m + n - 1) - 1。可以理解深搜的算法就是遍历了整个满二叉树(其实没有遍历整个满二叉树,只是近似而已)

    所以上面深搜代码的时间复杂度为O(2^(m + n - 1) - 1),可以看出,这是指数级别的时间复杂度,是非常大的。


动态规划

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

  • dp数组含义:到达(i,j)的所有路径共有dp[i] [j]种

  • 递推公式:dp[i] [j] = dp[i-1] [j] + dp[i] [j-1] (只能往右和往下走)

  • 初始化:由于每个dp[i] [j]都由左边的和上边得出,所以要先把最左边(j=0)和最上边(i=0)这两行初始化,全为1种方法

  • 遍历顺序:还是由于每个dp[i] [j]都由左边的和上边得出,所以要从左往右遍历,从上往下遍历

http://www.jsqmd.com/news/571855/

相关文章:

  • cool-admin(midway版)前端路由动画:实现与优化
  • Qwen1.5-1.8B-Chat-GPTQ-Int4开源大模型:vLLM在Kubernetes集群中的水平扩缩容实践
  • Pixel Language Portal 低代码平台集成:在 Dify 中快速构建像素语言应用
  • 基于 LLM 的金融文本分类实战:In-Context Learning 少样本落地(Qwen2.5+Ollama)
  • Flutter 实战避坑:相册页二次刷新被清空、全屏图片拉伸、ML Kit 人脸检测最小尺寸问题
  • 再议高中阶段的换元法 (上)
  • AtomGit「码动四季·开源同行」征稿活动来了,开源入门赛道怎么写更容易脱颖而出
  • python3中pyarrow库介绍和基础使用
  • 3步让Fiji在macOS上稳定运行:从启动崩溃到顺畅启动的完整指南
  • SingleFile:保存完整网页的终极解决方案
  • Lingbot-Depth-Pretrain-Vitl-14 在医疗影像的潜在应用:手术场景深度感知辅助
  • 3步突破AI编程助手限制:免费解锁Cursor Pro高级功能全指南
  • AutoGen Studio在内容创作领域的应用:自动化文案生成
  • 告别游戏本性能枷锁:OmenSuperHub的硬件轻控方案
  • 教程创作加速器:用快马平台秒建Vue3项目原型,专注编写安装指南
  • 2026年,探寻市场口碑佳的高压电磁阀靠谱工厂
  • 树莓派新手必看:保姆级vim安装与配置指南(含国内源切换和常见报错解决)
  • 企业数据安全新选择:手把手教你用Open Notebook搭建私有知识库,支持PDF/Word多格式导入
  • 在QT中将多个项目(同代码不同ui和资源文件)合并
  • DeepSeek-Coder-V2:打破闭源垄断,开启开源代码智能新时代的终极指南
  • SpringSecurity多认证方案配置实战:DelegatingAuthenticationEntryPoint的灵活运用
  • 我爱学算法之——动态规划(三)
  • 【Openlayers】突破天地图缩放限制:自定义TileGrid实现18级以上影像平滑展示
  • 5个Reloadium高级调试技巧:帧重载、错误处理和闭包调试终极指南
  • 2026年行业推荐的几个高品质柔性无尘拖链品牌厂家榜单
  • w3x2lni:魔兽地图跨版本兼容解决方案技术指南
  • HoRain云--Vue3样式绑定终极指南
  • JetBrains IDE试用期管理工具:技术解析与实践指南
  • 从社区到家庭,这几个比较好用的健康一体机厂家值得关注 - 品牌2026
  • 补题--25届acm校队训练赛