算法 第39天 动态规划2

news/2025/2/15 16:06:08/

62 不同路径

一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 “Start” )。

机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 “Finish” )。

问总共有多少条不同的路径?

在这里插入图片描述

# 递归
def uniquePaths(m:int,n:int)->int:if m==1 or n==1:return 1return uniquePaths(m-1,n)+uniquePaths(m,n-1)# 动态规划
def uniquePaths(m,n):dp=[[0]*n for _ in range(m)]: #dp[i][j]表示(0,0)到(i,j)有多少种方式到达for i in range(m):dp[i][0]=1for j in range(n):dp[0][j]=1for i in range(1,m):for j in range(1,n):dp[i][j]=dp[i-1][j]+dp[i][j-1]return dp[m-1][n-1]# 数论
def uniquePaths(m,n):numerator=1denominator=m-1count=m-1 #走到(m-1,n-1)横着走,一定要走m-1步t=m+n-2 #走到(m-1,n-1)一共需要m+n-2步while count>0:numerator*=tt-=1while denominator!=0 and numerator%denominator==0: #不能分子全部乘完/分母全部乘完  防止存储溢出numerator//==denominatordenominator-=1count-=1return numerator

63 不同路径II

一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 “Start” )。

机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 “Finish”)。

现在考虑网格中有障碍物。那么从左上角到右下角将会有多少条不同的路径?

网格中的障碍物和空位置分别用 1 和 0 来表示。

def uniquePathsWithObstacles(obstacleGrid:'List[List[int]]')->int:m=len(obstacleGrid)n=len(obstacleGrid[0])if obstacleGrid[m-1][n-1]==1 or obstacleGrid[0][0]==1:return 0dp=[[0]*n for _ in range(m)]for i in range(m):if obstacleGrid[i][0]==0:dp[i][0]=1else:breakfor j in range(n):if obstacleGrid[0][j]==0:dp[0][j]==1else:breakfor i in range(1,m):for j in range(1,n):if obstacleGrid[i][j]==1:continuedp[i][j]=dp[i-1][j]+dp[i][j-1]return dp[m-1][n-1]def uniquePathsWithObstacles(obstacleGrid):if obstacleGrid[m-1][n-1]==1 or obstacleGrid[0][0]==1:return 0m=len(obstacleGrid)n=len(obstacleGrid[0])dp=[0]*n#存储路径数for j in range(n):if obstacleGrid[0][j]==1breakdp[j]=1for i in range(1,m):if obstacleGrid[i][0]==1:dp[0]=0for j in range(1,n):if obstacleGrid[i][j]==1:dp[j]=0else:dp[j]+=dp[j-1]return dp[-1]

http://www.ppmy.cn/news/1418725.html

相关文章

微前端框架主流方案剖析

微前端架构是为了在解决单体应用在一个相对长的时间跨度下,由于参与的人员、团队的增多、变迁,从一个普通应用演变成一个巨石应用(Frontend Monolith)后,随之而来的应用不可维护的问题。这类问题在企业级 Web 应用中尤其常见。 微前端框架内的各个应用都支持独立开发部署、不…

xss攻击原理与解决方法

概述 XSS攻击是Web攻击中最常见的攻击方法之一,它是通过对网页注入可执行代码且成功地被浏览器 执行,达到攻击的目的,形成了一次有效XSS攻击,一旦攻击成功,它可以获取用户的联系人列 表,然后向联系人发送虚…

系统架构设计与优化的几个关键点

1. 业务理解与需求分析 业务场景梳理:深入理解业务流程、业务规则、用户行为模式等,明确系统需要支持的核心功能和应用场景。非功能性需求识别:关注性能指标(如响应时间、并发处理能力、数据吞吐量等)、可用性要求&am…

记录一下MySQL8版本更改密码规则

#查看当前密码策略 show variables like validate_password%;#修改密码等级为low set global validate_password.policy LOW; #注意MySQL8版本这是点,不是_#修改密码长度为6 set global validate_password.length 6;#查询我的数据库中user表host和user select host,…

Windows Server 2016虚拟机安装教程

一、VMware Workstation虚拟机软件的下载 官网下载入口:​​​​​​Download VMware Workstation Pro - VMware Customer Connect​​​​​ 下载好之后自己看着提示安装软件就好. 二、镜像文件的下载 下载网站入口:MSDN, 我告诉你 - 做一个安静…

Pandas相比Excel的优势是哪些?

熟悉Pandas的同学会知道,Pandas相当于Python中的Excel,都是基于二维表的进行数据处理分析,不同的是,Pandas基于代码操作数据,Excel是图形化的分析工具。 不少人会问Excel比Pandas更简单,为什么还要学习Pan…

Unity类银河恶魔城学习记录12-14 p136 Merge Skill Tree with Sword skill源代码

Alex教程每一P的教程原代码加上我自己的理解初步理解写的注释,可供学习Alex教程的人参考 此代码仅为较上一P有所改变的代码 【Unity教程】从0编程制作类银河恶魔城游戏_哔哩哔哩_bilibili CharacterStats.cs using System.Collections; using System.Collections.…

MCU最小系统的电源模块设计和复位模块的设计

最小操作系统就是一个电路,这个电路里面必须要的东西(如人需要喝水吃饭温度等情况,才能或者) 现在我们要解决这三个问题 这里V开头的,都是电源管脚 这里解释一下: 这里要注意哪些是电路电压,哪…