穿越障碍:最小路径和的高效算法比较【python力扣题64】

2024-04-25 12:36

本文主要是介绍穿越障碍:最小路径和的高效算法比较【python力扣题64】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作者介绍:10年大厂数据\经营分析经验,现任大厂数据部门负责人。
会一些的技术:数据分析、算法、SQL、大数据相关、python
欢迎加入社区:码上找工作
作者专栏每日更新:
LeetCode解锁1000题: 打怪升级之旅
python数据分析可视化:企业实战案例
备注说明:方便大家阅读,统一使用python,带必要注释,公众号 数据分析螺丝钉 一起打怪升级

题目描述

给定一个包含非负整数的 m x n 网格 grid,现在你需要找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。

:每次只能向下或者向右移动一步。

输入格式
  • grid:二维数组,其中的元素表示网格中的点的值。
输出格式
  • 返回一个整数,表示所有可能路径中的最小和。

示例

示例 1
输入: grid = [[1,3,1],[1,5,1],[4,2,1]
]
输出: 7
解释: 因为路径 1→3→1→1→1 的总和最小。
示例 2
输入: grid = [[1,2,3],[4,5,6]
]
输出: 12

方法一:动态规划

解题步骤
  1. 定义状态:创建一个同样大小的二维数组 dp,其中 dp[i][j] 表示到达点 (i, j) 的最小路径和。
  2. 初始化状态:第一行和第一列的元素只能由它的左边或上边来,所以是累加当前行或列的值。
  3. 状态转移:对于其他位置,dp[i][j] 由它的左边和上边的较小值加上当前网格值得到,即 dp[i][j] = min(dp[i-1][j], dp[i][j-1]) + grid[i][j]
  4. 返回结果dp[m-1][n-1] 即为最小路径和。
完整的规范代码
def minPathSum(grid):"""使用动态规划解决最小路径和问题:param grid: List[List[int]], 网格:return: int, 最小路径和"""m, n = len(grid), len(grid[0])dp = [[0]*n for _ in range(m)]dp[0][0] = grid[0][0]for i in range(1, m):dp[i][0] = dp[i-1][0] + grid[i][0]for j in range(1, n):dp[0][j] = dp[0][j-1] + grid[0][j]for i in range(1, m):for j in range(1, n):dp[i][j] = min(dp[i-1][j], dp[i][j-1]) + grid[i][j]return dp[m-1][n-1]# 示例调用
print(minPathSum([[1,3,1],[1,5,1],[4,2,1]
]))  # 输出: 7
print(minPathSum([[1,2,3],[4,5,6]
]))  # 输出: 12
算法分析
  • 时间复杂度:(O(m * n)),需要遍历整个网格一次。
  • 空间复杂度:(O(m * n)),使用了一个同样大小的二维数组。

方法二:空间优化的动态规划

解题步骤
  1. 使用一维数组:只用一个长度为 n 的数组来保存当前行的 dp 值。
  2. 迭代更新:每次更新时,dp[j] 更新为 dp[j](从上一行继承下来的,即上方)和 dp[j-1](当前行左边的,即左方)中的较小值加上当前点的值。
完整的规范代码
def minPathSum(grid):"""使用一维数组进行动态规划,空间优化版本:param grid: List[List[int]], 网格:return: int, 最小路径和"""m, n = len(grid), len(grid[0])dp = [0] * ndp[0] = grid[0][0]for j in range(1, n):dp[j] = dp[j-1] + grid[0][j]for i in range(1, m):dp[0] += grid[i][0]for j in range(1, n):dp[j] = min(dp[j-1], dp[j]) + grid[i][j]return dp[n-1]# 示例调用
print(minPathSum([[1,3,1],[1,5,1],[4,2,1]
]))  # 输出: 7
print(minPathSum([[1,2,3],[4,5,6]
]))  # 输出: 12
算法分析
  • 时间复杂度:(O(m * n)),需要遍历整个网格一次。
  • 空间复杂度:(O(n)),使用了一个长度为列数 n 的数组。

方法三:递归 + 记忆化

解题步骤
  1. 递归定义:定义一个递归函数,用于计算到达 (i, j) 的最小路径和。
  2. 记忆化存储:使用一个字典或数组来存储已经计算过的结果,避免重复计算。
完整的规范代码
def minPathSum(grid):"""使用递归和记忆化搜索解决最小路径和问题:param grid: List[List[int]], 网格:return: int, 最小路径和"""from functools import lru_cachem, n = len(grid), len(grid[0])@lru_cache(None)def dfs(i, j):if i == 0 and j == 0:return grid[i][j]if i < 0 or j < 0:return float('inf')return grid[i][j] + min(dfs(i-1, j), dfs(i, j-1))return dfs(m-1, n-1)# 示例调用
print(minPathSum([[1,3,1],[1,5,1],[4,2,1]
]))  # 输出: 7
print(minPathSum([[1,2,3],[4,5,6]
]))  # 输出: 12
算法分析
  • 时间复杂度:(O(m * n)),每个点最多计算一次,利用记忆化避免重复计算。
  • 空间复杂度:(O(m * n)),记忆化需要的空间。

方法四:从终点到起点的动态规划

解题步骤
  1. 反向动态规划:从网格的右下角开始,向左上角逐步计算。
  2. 更新规则:每个点的最小路径和取决于其右边和下边的点的最小路径和。
完整的规范代码
def minPathSum(grid):"""使用反向动态规划解决最小路径和问题:param grid: List[List[int]], 网格:return: int, 最小路径和"""m, n = len(grid), len(grid[0])for i in range(m-2, -1, -1):grid[i][n-1] += grid[i+1][n-1]for j in range(n-2, -1, -1):grid[m-1][j] += grid[m-1][j+1]for i in range(m-2, -1, -1):for j in range(n-2, -1, -1):grid[i][j] += min(grid[i+1][j], grid[i][j+1])return grid[0][0]# 示例调用
print(minPathSum([[1,3,1],[1,5,1],[4,2,1]
]))  # 输出: 7
print(minPathSum([[1,2,3],[4,5,6]
]))  # 输出: 12
算法分析
  • 时间复杂度:(O(m * n)),需要遍历整个网格一次。
  • 空间复杂度:(O(1)),直接在输入网格上进行修改,不需要额外空间。

方法五:改进的BFS

解题步骤
  1. 队列实现BFS:使用队列来实现广度优先搜索,每次处理一层。
  2. 累计最小和:使用额外的二维数组来保存到每个点的最小路径和。
  3. 优先队列优化:使用优先队列(小顶堆)来优先处理当前路径和最小的节点,以快速找到最小路径和。
完整的规范代码
from heapq import heappush, heappopdef minPathSum(grid):"""使用改进的BFS和优先队列解决最小路径和问题:param grid: List[List[int]], 网格:return: int, 最小路径和"""m, n = len(grid), len(grid[0])minHeap = [(grid[0][0], 0, 0)]  # (cost, x, y)costs = [[float('inf')] * n for _ in range(m)]costs[0][0] = grid[0][0]while minHeap:cost, x, y = heappop(minHeap)for dx, dy in [(1, 0), (0, 1)]:nx, ny = x + dx, y + dyif 0 <= nx < m and 0 <= ny < n:new_cost = cost + grid[nx][ny]if new_cost < costs[nx][ny]:costs[nx][ny] = new_costheappush(minHeap, (new_cost, nx, ny))return costs[m-1][n-1]# 示例调用
print(minPathSum([[1,3,1],[1,5,1],[4,2,1]
]))  # 输出: 7
print(minPathSum([[1,2,3],[4,5,6]
]))  # 输出: 12
算法分析
  • 时间复杂度:(O(m * n \log(m * n))),每个节点可能多次进入堆。
  • 空间复杂度:(O(m * n)),用于存储路径成本和堆结构。

不同算法的优劣势对比

特征方法一: 动态规划方法二: 空间优化DP方法三: 递归+记忆化方法四: 反向DP方法五: BFS+优先队列
时间复杂度(O(m * n))(O(m * n))(O(m * n))(O(m * n))(O(m * n \log(m * n)))
空间复杂度(O(m * n))(O(n))(O(m * n))(O(1))(O(m * n))
优势直观,易理解空间效率高避免重复计算,减少计算次数不需要额外空间,原地修改可以更快地找到最小路径和
劣势空间占用高仅限于列优化需要辅助空间存储递归状态修改输入数据计算和空间复杂度较高

应用示例

机器人导航系统
在自动化仓库或智能制造系统中,机器人需要找到成本最低的路径来移动货物或执行任务。动态规划方法可以有效地计算出从起点到终点的最低成本路径,提高系统的效率和响应速度。此外,实时路径规划系统可以利用优先队列优化的BFS来快速调整路径,以应对动态变化的环境条件,如临时障碍或优先级任务。

这篇关于穿越障碍:最小路径和的高效算法比较【python力扣题64】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

VSCode配置Anaconda Python环境的实现

《VSCode配置AnacondaPython环境的实现》VisualStudioCode中可以使用Anaconda环境进行Python开发,本文主要介绍了VSCode配置AnacondaPytho... 目录前言一、安装 Visual Studio Code 和 Anaconda二、创建或激活 conda

pytorch+torchvision+python版本对应及环境安装

《pytorch+torchvision+python版本对应及环境安装》本文主要介绍了pytorch+torchvision+python版本对应及环境安装,安装过程中需要注意Numpy版本的降级,... 目录一、版本对应二、安装命令(pip)1. 版本2. 安装全过程3. 命令相关解释参考文章一、版本对

Windows系统下如何查找JDK的安装路径

《Windows系统下如何查找JDK的安装路径》:本文主要介绍Windows系统下如何查找JDK的安装路径,文中介绍了三种方法,分别是通过命令行检查、使用verbose选项查找jre目录、以及查看... 目录一、确认是否安装了JDK二、查找路径三、另外一种方式如果很久之前安装了JDK,或者在别人的电脑上,想

讯飞webapi语音识别接口调用示例代码(python)

《讯飞webapi语音识别接口调用示例代码(python)》:本文主要介绍如何使用Python3调用讯飞WebAPI语音识别接口,重点解决了在处理语音识别结果时判断是否为最后一帧的问题,通过运行代... 目录前言一、环境二、引入库三、代码实例四、运行结果五、总结前言基于python3 讯飞webAPI语音

基于Python开发PDF转PNG的可视化工具

《基于Python开发PDF转PNG的可视化工具》在数字文档处理领域,PDF到图像格式的转换是常见需求,本文介绍如何利用Python的PyMuPDF库和Tkinter框架开发一个带图形界面的PDF转P... 目录一、引言二、功能特性三、技术架构1. 技术栈组成2. 系统架构javascript设计3.效果图

Python如何在Word中生成多种不同类型的图表

《Python如何在Word中生成多种不同类型的图表》Word文档中插入图表不仅能直观呈现数据,还能提升文档的可读性和专业性,本文将介绍如何使用Python在Word文档中创建和自定义各种图表,需要的... 目录在Word中创建柱形图在Word中创建条形图在Word中创建折线图在Word中创建饼图在Word

Python Excel实现自动添加编号

《PythonExcel实现自动添加编号》这篇文章主要为大家详细介绍了如何使用Python在Excel中实现自动添加编号效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、背景介绍2、库的安装3、核心代码4、完整代码1、背景介绍简单的说,就是在Excel中有一列h=会有重复

Python FastAPI入门安装使用

《PythonFastAPI入门安装使用》FastAPI是一个现代、快速的PythonWeb框架,用于构建API,它基于Python3.6+的类型提示特性,使得代码更加简洁且易于绶护,这篇文章主要介... 目录第一节:FastAPI入门一、FastAPI框架介绍什么是ASGI服务(WSGI)二、FastAP

Python中Windows和macOS文件路径格式不一致的解决方法

《Python中Windows和macOS文件路径格式不一致的解决方法》在Python中,Windows和macOS的文件路径字符串格式不一致主要体现在路径分隔符上,这种差异可能导致跨平台代码在处理文... 目录方法 1:使用 os.path 模块方法 2:使用 pathlib 模块(推荐)方法 3:统一使

一文教你解决Python不支持中文路径的问题

《一文教你解决Python不支持中文路径的问题》Python是一种广泛使用的高级编程语言,然而在处理包含中文字符的文件路径时,Python有时会表现出一些不友好的行为,下面小编就来为大家介绍一下具体的... 目录问题背景解决方案1. 设置正确的文件编码2. 使用pathlib模块3. 转换路径为Unicod