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

LeetCode:63. 不同路径 II

跟着carl学算法,本系列博客仅做个人记录,建议大家都去看carl本人的博客,写的真的很好的!
代码随想录

LeetCode:63. 不同路径 II
给定一个 m x n 的整数数组 grid。一个机器人初始位于 左上角(即 grid[0][0])。机器人尝试移动到 右下角(即 grid[m - 1][n - 1])。机器人每次只能向下或者向右移动一步。
网格中的障碍物和空位置分别用 1 和 0 来表示。机器人的移动路径中不能包含任何有障碍物的方格。
返回机器人能够到达右下角的不同路径数量。
测试用例保证答案小于等于 2 * 109。
示例 1:
在这里插入图片描述
输入:obstacleGrid = [[0,0,0],[0,1,0],[0,0,0]]
输出:2
解释:3x3 网格的正中间有一个障碍物。
从左上角到右下角一共有 2 条不同的路径:

  1. 向右 -> 向右 -> 向下 -> 向下
  2. 向下 -> 向下 -> 向右 -> 向右
    示例 2:
    在这里插入图片描述
    输入:obstacleGrid = [[0,1],[0,0]]
    输出:1
  • 需要注意初始化的代码
	// 这种遇到障碍物则立即终止,后面的都为0for (int i = 0; i < n && obstacleGrid[0][i] == 0; i++) {dp[0][i] = 1;}// 这种遇到障碍物还会继续向后遍历,在这里面是错误的初始化方式for (int i = 0; i < n; i++) {if (obstacleGrid[0][i] != 1) {dp[0][i] = 1;}}
	public int uniquePathsWithObstacles(int[][] obstacleGrid) {int m = obstacleGrid.length;int n = obstacleGrid[0].length;int[][] dp = new int[m][n];if (obstacleGrid[0][0] == 1 || obstacleGrid[m - 1][n - 1] == 1)return 0;for (int i = 0; i < m && obstacleGrid[i][0] == 0; i++) {dp[i][0] = 1;}for (int i = 0; i < n && obstacleGrid[0][i] == 0; i++) {dp[0][i] = 1;}for (int i = 1; i < m; i++) {for (int j = 1; j < n; j++) {if (obstacleGrid[i][j] == 0) {dp[i][j] = dp[i - 1][j] + dp[i][j - 1];}}}return dp[m - 1][n - 1];}
http://www.lryc.cn/news/528657.html

相关文章:

  • 安装zsh并美化
  • 读量子霸权18读后总结与感想兼导读
  • 统计学中的样本概率论中的样本
  • HTML 符号详解
  • 蓝桥杯练习日常|c/c++竞赛常用库函数(下)
  • Python vLLM 实战应用指南
  • .NET MAUI 入门学习指南
  • JavaScript系列(49)--游戏引擎实现详解
  • AI如何帮助解决生活中的琐碎难题?
  • K8s运维管理平台 - KubeSphere 3.x 和4.x 使用分析:功能较强,UI美观
  • 芯片AI深度实战:基础篇之langchain
  • WordPress使用(1)
  • 单机伪分布Hadoop详细配置
  • 【高内聚】设计模式是如何让软件更好做到高内聚的?
  • 10.2 目录(文件夹)操作
  • LiteFlow Spring boot使用方式
  • OSCP:Windows 服务提权详解
  • 星火大模型接入及文本生成HTTP流式、非流式接口(JAVA)
  • 21.Word:小赵-毕业论文排版❗【39】
  • Python中的函数(上)
  • Windows11 安装poetry
  • 浅谈Linux 权限、压缩、进程与服务
  • 006 LocalStorage和SessionStorage
  • AJAX RSS Reader:技术解析与应用场景
  • Go优雅实现redis分布式锁
  • 本地部署deepseek模型步骤
  • (2025 年最新)MacOS Redis Desktop Manager中文版下载,附详细图文
  • C++ 写一个简单的加减法计算器
  • 计算机网络基础 - 链路层(3)
  • ray.rllib 入门实践-5: 训练算法