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

动态规划5:62. 不同路径

动态规划解题步骤:

1.确定状态表示:dp[i]是什么

2.确定状态转移方程:dp[i]等于什么

3.初始化:确保状态转移方程不越界

4.确定填表顺序:根据状态转移方程即可确定填表顺序

5.确定返回值

题目链接:62. 不同路径 - 力扣(LeetCode)

题解:

1. 状态表示:dp[i]表示到达[i,j]位置有几种方法

2.状态转移方程:dp[i][j]=dp[i-1][j]+dp[i][j-1]

3.初始化:初始化第一行和第一列,值为1

4.填表顺序:遍历二维数组依次填写

5.返回值:dp[m-1][n-1]

class Solution {
public:int uniquePaths(int m, int n) {//创建dp表vector<vector<int>> dp(m);for(int i=0;i<m;++i) dp[i].resize(n);//初始化for(int i=0;i<m;++i) dp[i][0]=1;for(int j=0;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-1][j]+dp[i][j-1]

优化题解:

将初始化与填表合并,但是为了防止填表越界,需要多开一行一列空间,并且多开的空间需要填入合适的值以保证填表正确。本题需要使dp[0][1]=1,其余位置为0。注意返回值改变!

class Solution {
public:int uniquePaths(int m, int n) {//创建dp表(多开一行一列)vector<vector<int>> dp(m+1,vector<int>(n+1));//多开位置填值dp[0][1]=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][n];}
};
http://www.lryc.cn/news/362399.html

相关文章:

  • Python编程学习第一篇——Python零基础快速入门(五)-列表(List)
  • c# - 运算符 << 不能应用于 long 和 long 类型的操作数
  • 问题排查|记录一次基于mymuduo库开发的服务器错误排查(回响服务器无法正常工作)
  • 中介模式实现聊天室
  • 游戏开发与游戏设计区别
  • 卡尔曼滤波算法的matlab实现
  • Unity Obi Rope失效
  • 基于Nginx和Consul构建自动发现的Docker服务架构——非常之详细
  • Gnu/Linux 系统编程 - 如何获取帮助及一个演示
  • ffmpeg 的sws_scale接口函数解析
  • MoonBit 本周新增类型标注语法、继续进行核心库 API 整理工作
  • YOLOv10训练自己的数据集
  • 探索Web前端三大主流框架:Angular、React和Vue.js
  • 《HelloGitHub》第 98 期
  • Xtransfer面试内容
  • 论文笔记:Image Anaimation经典论文-运动关键点模型(Monkey-Net)
  • Kibana创建ElasticSearch 用户角色
  • Vue基础(2)响应式基础
  • Mysql基础教程(15):别名
  • SpringCloud 微服务中网关如何记录请求响应日志?
  • 【运维项目经历|028】Cobbler自动化部署平台构建项目
  • “物联网安全:万物互联背景下的隐私保护与数据安全策略“
  • LeetCode216组合总和3
  • 微软找腾讯接盘,Windows直接安装手机APP体验起飞了
  • 【Springcloud微服务】MybatisPlus下篇
  • i18n-demo
  • [Leetcode] 0-1背包和完全背包
  • 自定义类型:联合体和枚举
  • 【Cityengine】Cityengine生产带纹理的建筑模型导入UE4/UE5(下)
  • 详解51种企业应用架构模式