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

LeetCode 174.地下城游戏 Python题解

地下城游戏

# 地下城游戏
"""
恶魔们抓住了公主并将她关在了地下城dungeon的右下角。地下城是由mxn个房间组成的二维网格。我们英勇的骑士最初被安置在左上角的房间里,
他必须穿过地下城并通过对抗恶魔来拯救公主。
骑士的初始健康点数为一个正整数。如果他的健康点数在某一时刻降至0或以下,他会立即死亡。
有些房间由恶魔守卫,因此骑士在进入这些房间时会失去健康点数(若房间里的值为负整数,则表示骑士将损失健康点数);其他房间要么是空的(房间里的值为 0),
要么包含增加骑士健康点数的魔法球(若房间里的值为正整数,则表示骑士将增加健康点数)。
为了尽快解救公主,骑士决定每次只向右或向下移动一步。
返回确保骑士能够拯救到公主所需的最低初始健康点数。
注意:任何房间都可能对骑士的健康点数造成威胁,也可能增加骑士的健康点数,
包括骑士进入的左上角房间以及公主被监禁的右下角房间。
"""dungeon = [[-2, -3, 3], [-5, -10, 1], [10, 30, -5]]class Solution:def calculateMinimumHP(self, dungeon) -> int:m = len(dungeon)n = len(dungeon[0])res = [[9999] * (n + 1) for i in range(m + 1)]res[m][n - 1] = res[m - 1][n] = 1  # 反向dp最后肯定要多1的for i in range(m - 1, -1, -1):for j in range(n - 1, -1, -1):minn = min(res[i][j + 1], res[i + 1][j])  # 找下方或后方血量最小值res[i][j] = max(minn - dungeon[i][j], 1)  # 这个最难理解。print(res)return res[0][0]a = Solution()
print(a.calculateMinimumHP(dungeon))"""
这道题的思路就是反向dp,正向尝试过但是很麻烦麻烦,当很麻烦的时候说明思路肯定有问题的
最难理解的地方:最后是1然后就是最后-5 那1-(-5)就说明是最少6个-5上面是1 说明是6-1 到上面那一格之后最起码血量是5才够用左边是30 30够后面6用 说明到30那一个格子就应该最低是1即可那就是minn-dungeon[i][j]和1比大小就可以 最难的是这个地方
"""

相关文章:

LeetCode 174.地下城游戏 Python题解

地下城游戏 # 地下城游戏 """ 恶魔们抓住了公主并将她关在了地下城dungeon的右下角。地下城是由mxn个房间组成的二维网格。我们英勇的骑士最初被安置在左上角的房间里, 他必须穿过地下城并通过对抗恶魔来拯救公主。 骑士的初始健康点数为一个正整数…...

指令调用模板

也就是这边指令通过id和map会定位到一个结构体,然后这个结构再赋值两个成员,一个是函数一个是指令类型,然后这个函数是模板的实例化 使用的时候就传进去,这只是参数,最开始初始化的时候模板就已经实例化了。然后关于模…...

(五)关系数据库标准语言SQL

注:课堂讲义使用的数据库 5.1利用SQL语言建立数据库 5.1.1 create Database 5.1.2 create schema...authorization... 创建数据库和创建模式的区别: 数据库是架构的集合,架构是表的集合。但在MySQL中,他们使用的方式是相同的。 …...

第二十天-数据分析

1.介绍 1.什么是数据分析 1.以下4个纬度结合起来的数据科学 2.数据分析的特殊性...

鸿蒙Harmony应用开发—ArkTS声明式开发(通用属性:外描边设置)

设置组件外描边样式。 说明: 从API Version 11开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。 outline outline(value: OutlineOptions) 统一外描边样式设置接口。 卡片能力: 从API version 11开始,该…...

鸿蒙Harmony应用开发—ArkTS声明式开发(基础手势:CalendarPicker)

日历选择器组件,提供下拉日历弹窗,可以让用户选择日期。 说明: 该组件从API Version 10开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。 子组件 无 接口 CalendarPicker(options?: CalendarOptions) …...

wordpress免费主题下载

免费wordpress模板下载 简洁大气的文化艺术类wordpress模板,可以免费下载,实用易上手,新手也适合。 https://www.wpniu.com/themes/304.html 免费wordpress主题下载 高端大气上档次的wordpress主题,也可以是免费的,…...

【字典合集】SecLists-更全面的渗透测试字典 v2024.1

下路路径 SecLists-更全面的渗透测试字典 v2024.1 简介 SecLists 是一个致力于收集各种安全字典的开源项目。这些字典包括但不限于:密码字典、用户名字典、网络扫描结果、漏洞利用载荷、web shells、可用于渗透测试的Payloads、以及其他各种安全相关的字典。 这…...

PID控制器组(完整SCL代码)

PID控制器组不是什么新概念,是在PID控制器的基础上,利用面向对象的思想对对象进行封装 批量实例化。 1、增量式PID https://rxxw-control.blog.csdn.net/article/details/124363197https://rxxw-control.blog.csdn.net/article/details/1243631972、完全增量式PID https:/…...

五、OpenAI实战之Assistants API

在8线小城的革委会办公室里,黑8和革委会主任的对话再次展开。 黑8:主任,您知道吗?除了OpenAI API,现在还有一项新的技术叫做Assistants API,它可以帮助我们更好地进行对话和沟通。 主任:Assis…...

创邻科技获评环紫金港创新生态圈智源创新企业

3月1日,由杭州城西科创大走廊管理委员会指导,中共杭州市西湖区委员会、西湖区人民政府主办的“环紫金港创新生态圈”行动推进大会暨2024年紫金港科技城经济高质量发展大会在杭州举办。凭借重要的生态位置和创新业务成果,创邻科技受邀参会并被…...

CentOS7配置静态IP

文章目录 CentOS7配置静态IP一、前言1.场景2.环境 二、正文1)确定网络接口名称2)配置固定IP和DNS3)重启网络服务4)验证配置 CentOS7配置静态IP 一、前言 1.场景 在 CentOS7上设置静态 IP 和 DNS。 2.环境 CentOS Linux 版本&…...

【Python】正则

特殊字符转义 以下字符都需要用 反斜线(\)来进行特殊字符的转义。 \n - 换行符 \t - 制表符 \ - 反斜线本身 . - 点号(任意单个字符) 星号(0次或多次重复前面的元素) 加号(1次或多次重复前面的…...

Wilson威尔逊平滑

1、威尔逊平滑引入的动机 在曝光很少的情况下,计算出的CTR并不真实可靠,而样本数越大,CTR的比例才越准确,更能反应真实情况。 为了衡量样本数对于CTR信区间的影响,我们引入"威尔逊(Wilson&#xff0…...

Mac测试环境搭建

1 下载pycharm 下载地址:PyCharm:JetBrains 出品的用于数据科学和 Web 开发的 Python IDE 2 安装python3.6.8 下载地址:Index of /ftp/python/3.6.8/ 安装后提示错误 换一种方式:用conda 下载地址:Free Download | …...

Jira自动化的实用工具——ScriptRunner简介及最佳实践

近日,龙智举办的DevSecOps研讨会年终专场“趋势展望与实战探讨:如何打好DevOps基础、赋能创新”在上海圆满落幕。龙智Atlassian技术与顾问咨询团队,以及清晖、JamaSoftware、CloudBees等生态伙伴的嘉宾发表了主题演讲,分享他们在D…...

App拉起微信小程序参考文章

App拉起微信小程序参考文章h5页面跳转小程序-----明文URL Scheme_weixin://dl/business/?appid*appid*&path*path*&qu-CSDN博客文章浏览阅读561次,点赞16次,收藏5次。仅需两步,就能实现h5跳转小程序,明文 URL Scheme&…...

AcWing 4956. 冶炼金属

对于这个题,V越大,除出来的数就越小,V越小,除出来的数就越大,当我们找一个最大和最小值的时候,就可以通过这个性质进行二分来求解。 可以通过求满足 [ A V ] [\frac{A}{V}] [VA​] 小于等于 B B B的最小的…...

记一次面试经历

这段时间正好是金三银四的黄金时间段,正好这段时间也有很多企业有hc在招人,本文主要就是来聊聊我这段时间的面试经历吧。目前我是从北京投上海的岗位,现在有两家保底的offer。 简历投递 简历这块是基础也是必要的门槛,有没有面试…...

js【详解】DOM

文档对象模型(Document Object Model,简称DOM) DOM 是哪种数据结构 ? DOM 的本质是浏览器通过HTML代码解析出来的一棵 树。 操作 DOM 常用的 API 有哪些 ? 获取 DOM 节点 //方式 1:通过【id】获取&#xf…...

AI读脸术分布式部署:多节点负载均衡实战方案

AI读脸术分布式部署:多节点负载均衡实战方案 1. 项目背景与需求 在现代人工智能应用中,人脸属性识别技术已经成为许多业务场景的核心需求。从智能安防到个性化推荐,从用户分析到内容审核,准确快速的年龄和性别识别能力正在发挥越…...

3分钟快速上手:Windows系统终极Btrfs驱动完全指南

3分钟快速上手:Windows系统终极Btrfs驱动完全指南 【免费下载链接】btrfs WinBtrfs - an open-source btrfs driver for Windows 项目地址: https://gitcode.com/gh_mirrors/bt/btrfs 你是否曾羡慕Linux用户能享受Btrfs文件系统的强大功能,却苦于…...

终极Minecraft服务器包创建指南:ServerPackCreator如何让服务器搭建变得简单快速

终极Minecraft服务器包创建指南:ServerPackCreator如何让服务器搭建变得简单快速 【免费下载链接】ServerPackCreator Create a server pack from a Minecraft Forge, NeoForge, Fabric, LegacyFabric or Quilt modpack! 项目地址: https://gitcode.com/gh_mirror…...

新手必看:Qwen3-Reranker-0.6B部署避坑指南与常见问题

新手必看:Qwen3-Reranker-0.6B部署避坑指南与常见问题 1. 为什么选择Qwen3-Reranker-0.6B 1.1 轻量高效的语义重排序模型 Qwen3-Reranker-0.6B是阿里云推出的轻量级重排序模型,仅有0.6B参数(约6亿),但性能表现优异。…...

从零到精通:Windows系统风扇控制终极方案深度解析

从零到精通:Windows系统风扇控制终极方案深度解析 【免费下载链接】FanControl.Releases This is the release repository for Fan Control, a highly customizable fan controlling software for Windows. 项目地址: https://gitcode.com/GitHub_Trending/fa/Fan…...

保姆级教程:在ArmSoM-W3开发板上用QT+MPP+FFmpeg搞定四路RTSP硬解码(附完整代码)

RK3588开发板实战:QTMPPFFmpeg四路RTSP硬解码全流程解析 第一次拿到ArmSoM-W3开发板时,面对RK3588这颗性能怪兽,很多开发者都会好奇如何充分发挥它的多媒体处理能力。特别是在安防监控、智能视觉等场景中,实现多路高清视频流的实时…...

信道估计以及信道均衡的SINR计算详解

一、基础入门:核心概念简单理解 本次学习的核心是“信道均衡”和“SINR”,先通过通俗类比掌握基础定义,为后续复杂原理铺垫。 1. 信道均衡是什么? 类比:我们在嘈杂的房间里听人说话,房间的回声(对应信道失真)、环境噪音(对应噪声)会让我们听不清,“信道均衡”就相…...

一键部署后:BERT文本分割模型健康检查与监控

一键部署后:BERT文本分割模型健康检查与监控 部署一个BERT文本分割模型,看着服务成功启动,这只是万里长征的第一步。接下来,你可能会有这样的疑问:我的服务真的在稳定运行吗?它处理请求的速度够快吗&#…...

Phi-3 Forest Laboratory 数据处理实战:Excel VLOOKUP函数复杂场景的智能解决方案

Phi-3 Forest Laboratory 数据处理实战:Excel VLOOKUP函数复杂场景的智能解决方案 你是不是也遇到过这种情况?面对一份庞大的销售数据表,想用VLOOKUP函数把客户信息和订单金额匹配起来,结果要么是满屏的#N/A错误,要么…...

丹青识画系统C语言基础集成示例:轻量级嵌入式图像处理接口

丹青识画系统C语言基础集成示例:轻量级嵌入式图像处理接口 最近在做一个智能门禁的项目,需要在树莓派这类小设备上跑图像识别。找了一圈,发现很多现成的AI模型库要么太臃肿,要么对C语言支持不友好,部署起来特别麻烦。…...