算法的重要性,我就不多说了吧,想去大厂,就必须要经过基础知识和业务逻辑面试+算法面试。所以,为了提高大家的算法能力,这个公众号后续每天带大家做一道算法题,题目就从LeetCode上面选 !

今天和大家聊的问题叫做 地下城游戏  ,我们先来看题面:

https://leetcode-cn.com/problems/dungeon-game/

Write a function to determine the knight's minimum initial health so that he is able to rescue the princess.

For example, given the dungeon below, the initial health of the knight must be at least 7 if he follows the optimal path RIGHT-> RIGHT -> DOWN -> DOWN.

题意

一些恶魔抓住了公主(P)并将她关在了地下城的右下角。地下城是由 M x N 个房间组成的二维网格。我们英勇的骑士(K)最初被安置在左上角的房间里,他必须穿过地下城并通过对抗恶魔来拯救公主。

骑士的初始健康点数为一个正整数。如果他的健康点数在某一时刻降至 0 或以下,他会立即死亡。

有些房间由恶魔守卫,因此骑士在进入这些房间时会失去健康点数(若房间里的值为负整数,则表示骑士将损失健康点数);其他房间要么是空的(房间里的值为 0),要么包含增加骑士健康点数的魔法球(若房间里的值为正整数,则表示骑士将增加健康点数)。

为了尽快到达公主,骑士决定每次只向右或向下移动一步。

解题

https://blog.csdn.net/qq_17550379/article/details/86243097

一看到这个问题首先想到的就是动态规划,其次想的就是自顶向下,但是这样想的话就会有一个问题,就是我们需要判断每次到达一个房间后,我们的血量不能是负数,这给我们编写代码造成了很大的困难。如果采用自底向上的思路去做的话,那么问题就会变得简单很多(而且我觉得你应该做到,拿到这个问题首先想到的就是自底向上,这是一种直觉)。我们只需要取右和下的最小值(我们需要计算最少的能量),然后减去dungoen[i][j],并且保证到达当前房间后的血量大于等于0就行了

f(i,j)=max(0,min(f(i+1,j),f(i,j+1))−dungeon[i][j])

对于边界问题我们单独处理。最后我们只需要取结果f(0,0)+1即可(根据题目中的例子)。Python代码如下:

class Solution:def calculateMinimumHP(self, dungeon):""":type dungeon: List[List[int]]:rtype: int"""row, col = len(dungeon), len(dungeon[0])mem = [[0]*col for _ in range(row)]for i in range(row-1,-1,-1):for j in range(col-1,-1,-1):if i == row-1 and j == col-1:mem[i][j] = max(0, -dungeon[i][j])elif i == row-1:mem[i][j] = max(0, mem[i][j+1] - dungeon[i][j])elif j == col-1:mem[i][j] = max(0, mem[i+1][j] - dungeon[i][j])else:mem[i][j] = max(0, min(mem[i+1][j], mem[i][j+1]) - dungeon[i][j])return mem[0][0] + 1

好了,今天的文章就到这里,如果觉得有所收获,请顺手点个在看或者转发吧,你们的支持是我最大的动力 。

上期推文:

LeetCode1-160题汇总,希望对你有点帮助!

LeetCode刷题实战161:相隔为1的编辑距离

LeetCode刷题实战162:寻找峰值

LeetCode刷题实战163:缺失的区间

LeetCode刷题实战164:最大间距

LeetCode刷题实战165:比较版本号

LeetCode刷题实战166:分数到小数

LeetCode刷题实战167:两数之和 II - 输入有序数组

LeetCode刷题实战168:Excel表列名称

LeetCode刷题实战169:多数元素

LeetCode刷题实战170:两数之和 III - 数据结构设计

LeetCode刷题实战171:Excel表列序号

LeetCode刷题实战172:阶乘后的零

LeetCode刷题实战173:二叉搜索树迭代器

​LeetCode刷题实战174:地下城游戏相关推荐

  1. LeetCode刷题系列-- 174. 地下城游戏

    一些恶魔抓住了公主(P)并将她关在了地下城的右下角.地下城是由 M x N 个房间组成的二维网格.我们英勇的骑士(K)最初被安置在左上角的房间里,他必须穿过地下城并通过对抗恶魔来拯救公主. 骑士的初始 ...

  2. ​LeetCode刷题实战179:最大数

    算法的重要性,我就不多说了吧,想去大厂,就必须要经过基础知识和业务逻辑面试+算法面试.所以,为了提高大家的算法能力,这个公众号后续每天带大家做一道算法题,题目就从LeetCode上面选 ! 今天和大家 ...

  3. ​LeetCode刷题实战181: 超过经理收入的员工

    算法的重要性,我就不多说了吧,想去大厂,就必须要经过基础知识和业务逻辑面试+算法面试.所以,为了提高大家的算法能力,这个公众号后续每天带大家做一道算法题,题目就从LeetCode上面选 ! 今天和大家 ...

  4. ​LeetCode刷题实战517:超级洗衣机

    算法的重要性,我就不多说了吧,想去大厂,就必须要经过基础知识和业务逻辑面试+算法面试.所以,为了提高大家的算法能力,这个公众号后续每天带大家做一道算法题,题目就从LeetCode上面选 ! 今天和大家 ...

  5. ​LeetCode刷题实战535:TinyURL 的加密与解密

    算法的重要性,我就不多说了吧,想去大厂,就必须要经过基础知识和业务逻辑面试+算法面试.所以,为了提高大家的算法能力,这个公众号后续每天带大家做一道算法题,题目就从LeetCode上面选 ! 今天和大家 ...

  6. ​LeetCode刷题实战488:祖玛游戏

    算法的重要性,我就不多说了吧,想去大厂,就必须要经过基础知识和业务逻辑面试+算法面试.所以,为了提高大家的算法能力,这个公众号后续每天带大家做一道算法题,题目就从LeetCode上面选 ! 今天和大家 ...

  7. ​LeetCode刷题实战375:猜数字大小 II

    算法的重要性,我就不多说了吧,想去大厂,就必须要经过基础知识和业务逻辑面试+算法面试.所以,为了提高大家的算法能力,这个公众号后续每天带大家做一道算法题,题目就从LeetCode上面选 ! 今天和大家 ...

  8. ​LeetCode刷题实战50:Pow(x, n)

    算法的重要性,我就不多说了吧,想去大厂,就必须要经过基础知识和业务逻辑面试+算法面试.所以,为了提高大家的算法能力,这个公众号后续每天带大家做一道算法题,题目就从LeetCode上面选 ! 今天和大家 ...

  9. ​LeetCode刷题实战391:完美矩形

    算法的重要性,我就不多说了吧,想去大厂,就必须要经过基础知识和业务逻辑面试+算法面试.所以,为了提高大家的算法能力,这个公众号后续每天带大家做一道算法题,题目就从LeetCode上面选 ! 今天和大家 ...

最新文章

  1. 身份证丢失后被刷脸欠上万贷款,银行:人脸识别到就是你借的!
  2. IDEA快速入门(Mac版)
  3. jquery实现定时调度(倒计时)
  4. jdbc如何写csv文件_Java:将JDBC结果集作为CSV流化
  5. 柱形图无数据可选中_Excel – 如何制作出上下层排列的柱形图?
  6. 零值比较--BOOL,int,float,指针变量与零值比
  7. 反射实现方法调用(1):执行机制
  8. flamengo x ajax,Flamengo是什么意思
  9. Atitit jsr规范化分类 attilax总结
  10. 中职计算机办公自动化教学,中职学校计算机办公自动化教学现状分析.pdf
  11. 计算机485通讯原理图,485通讯接线图.pdf
  12. matlab 字符查找函数,matlab字符函数
  13. 彻底删除双系统的解决办法(UEFI启动)
  14. MIS系统(13)- 系统管理之权限管理
  15. 曾国藩:人生的三个阶段,做对了,剩下就是好运气
  16. Android 新浪微博 授权失败 21337
  17. libreoffice7.0 离线安装
  18. java面试宝典2017
  19. 需要达到什么水平才能找到一份计算机实习?
  20. OpenCV实战——基于GrabCut算法的图像分割

热门文章

  1. 扫雷,潜伏者(python)
  2. 深圳美景品牌策划机构:英国知名时尚鞋履品牌IGX签约美景策划
  3. dx12 龙书第二十一章学习笔记 -- 环境光遮蔽
  4. 嵌入式驱动编写-点亮LED驱动程序
  5. 如何聪明的提问(职场的必踩坑)
  6. dotnet 进行二进制差分压缩文件
  7. scala.Predef$.$conforms()Lscala/Predef$$less$colon$less;
  8. 一体化步进伺服电机在插件机中的应用
  9. 计蒜客 17115 Coin(2017 ACM-ICPC 亚洲区(西安赛区)网络赛 B)
  10. 服务器被DDOS或CC攻击了怎么办