【力扣一刷】代码随想录day39(动态规划part2:62.不同路径、63. 不同路径 II )

本文主要是介绍【力扣一刷】代码随想录day39(动态规划part2:62.不同路径、63. 不同路径 II ),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

【62.不同路径】中等题

方法一  只初始化start位置

方法二  初始化第一行和第一列

【63. 不同路径 II】中等题


【62.不同路径】中等题

思路:

1、前提:只能向右或向下移动一步,当前格子只能由左边(向右移)或上边(向下移)到达

2、递推关系:到达当前格子的路径数 = 到达左边格子的路径数 + 到达上边格子的路径数

方法一  只初始化start位置

思路:

1、设置start位置的初始值为1

2、计算到达当前格子的路径数:当前格子只能由左边(向右移)或上边(向下移)到达

  • 第一行只加左边
  • 第一列只加上边
  • 其余情况,左边+上边
class Solution {public int uniquePaths(int m, int n) {int[][] matric = new int[m][n];for (int i = 0; i < m; i++){for (int j = 0; j < n; j++){if (i == 0 && j == 0) {matric[i][j] = 1; // 注意:start位置的值为1continue;}// 当前格子只能由左边(向右移)或上边(向下移)到达if (i == 0) matric[i][j] = matric[i][j-1]; // 第一行只加左边else if (j == 0) matric[i][j] = matric[i-1][j]; // 第一列只加上边else matric[i][j] = matric[i][j-1] + matric[i-1][j]; // 其余情况,左边+上边}}return matric[m-1][n-1];}
}
  • 时间复杂度:O(m×n)
  • 空间复杂度:O(m×n)

方法二  初始化第一行和第一列

思路:

1、将第一行的格子和第一列的格子都初始化为1

2、其余格子都存在左边的格子和上边的格子,直接相加即可

class Solution {public int uniquePaths(int m, int n) {int[][] matric = new int[m][n];for (int j = 0; j < n; j++) matric[0][j] = 1;  // 将第一行的格子都初始化为1for (int i = 0; i < m; i++) matric[i][0] = 1;  // 将第一列的格子都初始化为1// 其余格子都存在左边的格子和上边的格子,直接相加即可for (int i = 1; i < m; i++){for (int j = 1; j < n; j++){matric[i][j] = matric[i][j-1] + matric[i-1][j];}}return matric[m-1][n-1];}
}
  • 时间复杂度:O(m×n)
  • 空间复杂度:O(m×n)


【63. 不同路径 II】中等题

思路:

1、如果开始位置或结束位置有障碍物,则肯定无法出发或到达,直接返回0

2、初始化第一行和第一列

  • 如果第一行某个格子出现障碍物,则当前格子以及右边的所有格子都无法到达(直接使用初始化的默认值0即可);如果当前格子没有障碍物,则直接设为1。
  • 如果第一列某个格子出现障碍物,则当前格子以及下边的所有格子都无法到达(直接使用初始化的默认值0即可);如果当前格子没有障碍物,则直接设为1。

3、遍历剩余格子

  • 如果当前格子有障碍物,则无法到达,设为0
  • 如果当前格子有障碍物,则到达当前格子的路径数 = 到达左边格子的路径数 + 到达上边格子的路径数
class Solution {public int uniquePathsWithObstacles(int[][] obstacleGrid) {int rows = obstacleGrid.length;int columns = obstacleGrid[0].length;int[][] matric = new int[rows][columns];// 如果开始位置或结束位置有障碍物,则肯定无法出发或到达,直接返回0if (obstacleGrid[0][0] == 1 || obstacleGrid[rows-1][columns-1] == 1) return 0;for (int j = 0; j < columns; j++){// 如果第一行某个格子出现障碍物,则当前格子以及右边的所有格子都无法到达(直接使用初始化的默认值0即可)if (obstacleGrid[0][j] == 1) break; // 如果当前格子没有障碍物else{matric[0][j] = 1;}}for (int i = 0; i < rows; i++){// 如果第一列某个格子出现障碍物,则当前格子以及下边的所有格子都无法到达(直接使用初始化的默认值0即可)if (obstacleGrid[i][0] == 1) break; // 如果当前格子没有障碍物else{matric[i][0] = 1;}}for (int i = 1; i < rows; i++){for (int j = 1; j < columns; j++){if (obstacleGrid[i][j] == 1) matric[i][j] = 0;else {matric[i][j] = matric[i-1][j] + matric[i][j-1];}}}return matric[rows-1][columns-1];}
}
  • 时间复杂度:O(m×n)
  • 空间复杂度:O(m×n)

这篇关于【力扣一刷】代码随想录day39(动态规划part2:62.不同路径、63. 不同路径 II )的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/902383

相关文章

第10章 中断和动态时钟显示

第10章 中断和动态时钟显示 从本章开始,按照书籍的划分,第10章开始就进入保护模式(Protected Mode)部分了,感觉从这里开始难度突然就增加了。 书中介绍了为什么有中断(Interrupt)的设计,中断的几种方式:外部硬件中断、内部中断和软中断。通过中断做了一个会走的时钟和屏幕上输入字符的程序。 我自己理解中断的一些作用: 为了更好的利用处理器的性能。协同快速和慢速设备一起工作

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

hdu2544(单源最短路径)

模板题: //题意:求1到n的最短路径,模板题#include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<queue>#include<set>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#i

动态规划---打家劫舍

题目: 你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。 给定一个代表每个房屋存放金额的非负整数数组,计算你 不触动警报装置的情况下 ,一夜之内能够偷窃到的最高金额。 思路: 动态规划五部曲: 1.确定dp数组及含义 dp数组是一维数组,dp[i]代表

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

uva 10061 How many zero's and how many digits ?(不同进制阶乘末尾几个0)+poj 1401

题意是求在base进制下的 n!的结果有几位数,末尾有几个0。 想起刚开始的时候做的一道10进制下的n阶乘末尾有几个零,以及之前有做过的一道n阶乘的位数。 当时都是在10进制下的。 10进制下的做法是: 1. n阶位数:直接 lg(n!)就是得数的位数。 2. n阶末尾0的个数:由于2 * 5 将会在得数中以0的形式存在,所以计算2或者计算5,由于因子中出现5必然出现2,所以直接一

poj 1734 (floyd求最小环并打印路径)

题意: 求图中的一个最小环,并打印路径。 解析: ans 保存最小环长度。 一直wa,最后终于找到原因,inf开太大爆掉了。。。 虽然0x3f3f3f3f用memset好用,但是还是有局限性。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#incl

软考系统规划与管理师考试证书含金量高吗?

2024年软考系统规划与管理师考试报名时间节点: 报名时间:2024年上半年软考将于3月中旬陆续开始报名 考试时间:上半年5月25日到28日,下半年11月9日到12日 分数线:所有科目成绩均须达到45分以上(包括45分)方可通过考试 成绩查询:可在“中国计算机技术职业资格网”上查询软考成绩 出成绩时间:预计在11月左右 证书领取时间:一般在考试成绩公布后3~4个月,各地领取时间有所不同