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

动态规划-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)

三、代码示例

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];}
};

 

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

 

 

http://www.xdnf.cn/news/4878.html

相关文章:

  • 量化解析美英协议的非对称冲击:多因子模型与波动率曲面重构
  • 支持向量机案例
  • springmvc实现文件上传
  • [6-1] TIM定时中断 江协科技学习笔记(45个知识点)
  • 布隆过滤器:高效的数据结构与应用详解
  • 通过Linux系统服务管理IoTDB集群的高效方法
  • C语言 第六章 结构体(2)
  • 大数据——Mac环境DataSpell集成Jupyter
  • 2025年5月通信科技领域周报(4.28-5.4):5G-A技术引领峰会通信 卫星通信加速全球化布局
  • 数据库系统概论(七)初识SQL与SQL基本概念
  • 小程序消息订阅的整个实现流程
  • 养生:开启健康生活的钥匙
  • buck和boost总结
  • B站pwn教程笔记-9
  • 使用 React Native实现鸿蒙开发的详细方案
  • 数据结构 集合类与复杂度
  • Windows平台下的Qt发布版程序打包成exe可执行文件(带图标)|Qt|C++
  • SPC:通过对抗性博弈,让LLM左右互搏提升性能
  • 【Linux】swap交换分区管理
  • 特殊版本,官宣永久免费
  • 从入门到深入:Vue.js 学习全攻略
  • C++ 模板方法模式详解与实例
  • 基于多模态大模型的十二指肠穿孔诊疗技术方案
  • NeurIPS 2024 | 工业质检缺陷检测相关论文梳理
  • el-table中合并表格后横向变高样式无效
  • 找不到自定义包出现报错ModuleNotFoundError: No module named
  • 基础编程题目集 6-9 统计个位数字
  • GAMES202-高质量实时渲染(Assignment 3)
  • Python 爬虫之 XPath 元素定位
  • 熔断机制的实战:高并发下怎么优雅“断电”保命?