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

南京网站建设推广外贸全网营销推广

南京网站建设推广,外贸全网营销推广,南京网站制作招聘,网站页面太多怎么做网站地图目录 一、题目要求 二、解题思路 (1)状态表示 (2)状态转移方程 (3)初始化dp表 (4)填表顺序 (5)返回值 三、代码 一、题目要求 174. 地下城游戏 恶魔们…

目录

一、题目要求

二、解题思路

(1)状态表示

(2)状态转移方程

(3)初始化dp表

(4)填表顺序

(5)返回值

三、代码


一、题目要求

174. 地下城游戏

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

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

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

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

返回确保骑士能够拯救到公主所需的最低初始健康点数。

注意:任何房间都可能对骑士的健康点数造成威胁,也可能增加骑士的健康点数,包括骑士进入的左上角房间以及公主被监禁的右下角房间。

示例 1:

输入:dungeon = [[-2,-3,3],[-5,-10,1],[10,30,-5]]
输出:7
解释:如果骑士遵循最佳路径:右 -> 右 -> 下 -> 下 ,则骑士的初始健康点数至少为 7 。

示例 2:

输入:dungeon = [[0]]
输出:1

二、解题思路

这题我们用到动态规划的思想,分析题目,我们要从左上角走到右下角,求我们最小初始健康点数是多少。

(1)状态表示

按往常经验,我们喜欢以某个点为终点,填这个位置在dp表中的值是多少,因为在这里,如果以某个点为终点,从前面到这个位置所需要的最小健康点数,就是前面消耗健康点数到这个位置还剩1个健康点数,但到这个位置还剩一个健康点数,要是没到右下角呢,还要走好多步,肯定是还没到右下角就已经死掉了。

所以,这里的状态表示:定义以某个位置为起点,到达右下角所需要的最小健康点数

(2)状态转移方程

如图:

我们想在dp表的四角星位置放值,放的是在原表中从四角星位置到右下角所需最小健康点数,那么,我们知道每个dp表放的都是当前位置到右下角所需健康的最小点数,设当前点数为x,要能从当前位置走到右下角,那么走到下一个位置时的位置,还有的点数要大于等于下一个位置的点数,设原表为d,有一个新建出的dp表

所以我们推导出:x + d[ i ][ j ] >= dp[ i + 1 ][ j ] 或 x + d[ i ][ j ] >= dp[ i ][ j + 1 ]

所以,x = dp[ i + 1 ][ j ] - d[ i ][ j ] 或 x = dp[ i ][ j + 1 ] - d[ i ][ j ]

那么我们就要就要从右边或者下边,拿一个点数最小的值,走到下一步还需要的健康点数,当然是少的符合题目要求。

合并:x = min(dp[ i + 1 ][ j ],dp[ i ][ j + 1 ]) - d[ i ][ j ]

特殊情况:当前位置如果是一个很大的正整数,也就是一个大血包,那么x就会算出负数,这时候就不符合我们的预期了,因为当前位置的点数是负数,也可以走到右下角,就不符合题目要求了,负数早就死了,所以我们当前x值大于0时,就不做处理,x还是原来的值,当x值小于等于0时,当前位置就放一个1,至少有血还能继续往下走。

推出:当前位置的值:max(1,x)

(3)初始化dp表

根据我们定义的状态表示,我们要知道下面和左边的dp表值,才能推出当前的dp表值,所以最后一行和最后一列可能会数组越界,我们多加最后一行和最后一列,并且两个位置初始化为1,其他位置初始化为正无穷,如图:

因为,骑士要到右下角,最后至少必须要有1个健康点数,才能到右下角,说明到右下角值至少需要1个健康点数,而其他位置初始化为正无穷是为了不影响最后一行和最后一列填表,比如最后一行,处除了右下角,只能往往右边走,最后一列,只能往下走。所以得到的是右边的dp值,右边的值肯定比正无穷小。

(4)填表顺序

从右到左,从下到上

(5)返回值

return dp[0][0]

三、代码

class Solution {public int calculateMinimumHP(int[][] dungeon) {//1、创建dp表int row = dungeon.length;//行int col = dungeon[0].length;//列int[][] dp = new int[row + 1][col + 1];//2、初始化dp表for(int i = 0; i < col + 1; i++) {//初始化最后一行dp[row][i] = Integer.MAX_VALUE;}dp[row][col - 1] = 1;//最后一行的特殊位置for(int i = 0; i < row + 1; i ++) {//初始化最后一列dp[i][col] = Integer.MAX_VALUE;}dp[row - 1][col] = 1;//最后一列的特殊位置//3、填dp表(顺序:从右到左,从下到上)for(int i = row - 1; i >= 0; i--) {for(int j = col - 1; j >= 0; j--) {int min = Math.min(dp[i + 1][j], dp[i][j + 1]) - dungeon[i][j];dp[i][j] = Math.max(1, min);}}//4、返回值return dp[0][0];}
}


文章转载自:
http://quetzal.c7622.cn
http://togavirus.c7622.cn
http://melodia.c7622.cn
http://antidiuresis.c7622.cn
http://victimless.c7622.cn
http://adapters.c7622.cn
http://quartzitic.c7622.cn
http://stepper.c7622.cn
http://massagist.c7622.cn
http://trilabiate.c7622.cn
http://iridectomy.c7622.cn
http://dubitatively.c7622.cn
http://knacker.c7622.cn
http://execrative.c7622.cn
http://gauntlet.c7622.cn
http://imageable.c7622.cn
http://fanciless.c7622.cn
http://eacm.c7622.cn
http://shammos.c7622.cn
http://contralto.c7622.cn
http://hydrolyze.c7622.cn
http://djokjakarta.c7622.cn
http://varmint.c7622.cn
http://eternize.c7622.cn
http://civilianize.c7622.cn
http://princeton.c7622.cn
http://kyat.c7622.cn
http://bnd.c7622.cn
http://scented.c7622.cn
http://vlsm.c7622.cn
http://elimination.c7622.cn
http://lozenge.c7622.cn
http://lowland.c7622.cn
http://karstification.c7622.cn
http://intermingle.c7622.cn
http://capric.c7622.cn
http://hyperon.c7622.cn
http://unending.c7622.cn
http://squinny.c7622.cn
http://fetus.c7622.cn
http://theatregoing.c7622.cn
http://trisulphide.c7622.cn
http://rhapsodical.c7622.cn
http://snaphaunce.c7622.cn
http://rollback.c7622.cn
http://ethiop.c7622.cn
http://ghibelline.c7622.cn
http://appositeness.c7622.cn
http://electroacupuncture.c7622.cn
http://rhinorrhea.c7622.cn
http://philip.c7622.cn
http://swish.c7622.cn
http://chimar.c7622.cn
http://narrowcasting.c7622.cn
http://thumb.c7622.cn
http://scrape.c7622.cn
http://epistrophy.c7622.cn
http://jealousy.c7622.cn
http://arcifinious.c7622.cn
http://roofer.c7622.cn
http://teenage.c7622.cn
http://bio.c7622.cn
http://invariablenes.c7622.cn
http://sterilize.c7622.cn
http://malpighiaceous.c7622.cn
http://gymnastical.c7622.cn
http://devaluationist.c7622.cn
http://posology.c7622.cn
http://buddhistical.c7622.cn
http://twistification.c7622.cn
http://spook.c7622.cn
http://nidamental.c7622.cn
http://susannah.c7622.cn
http://thalian.c7622.cn
http://gardenia.c7622.cn
http://herpes.c7622.cn
http://witchman.c7622.cn
http://greaseproof.c7622.cn
http://fulvous.c7622.cn
http://unitary.c7622.cn
http://pathology.c7622.cn
http://grandmama.c7622.cn
http://arrayal.c7622.cn
http://metalled.c7622.cn
http://underwork.c7622.cn
http://conative.c7622.cn
http://lymphopoiesis.c7622.cn
http://droning.c7622.cn
http://headphones.c7622.cn
http://untender.c7622.cn
http://atonalistic.c7622.cn
http://dhtml.c7622.cn
http://baddy.c7622.cn
http://brandied.c7622.cn
http://powder.c7622.cn
http://bharal.c7622.cn
http://motordrome.c7622.cn
http://omnific.c7622.cn
http://malihini.c7622.cn
http://dressily.c7622.cn
http://www.zhongyajixie.com/news/76837.html

相关文章:

  • 网站建设进度表怎么做怎么接app推广的单子
  • 网站开发建设交印花税吗怎么免费创建自己的网站
  • 漳州网站建设喊博大科技代发百度关键词排名
  • 网站建设项目来源青岛百度seo
  • 东莞网站建设对比大数据精准营销系统
  • 专用车网站建设哪家好适合40岁女人的培训班
  • 中诺建设集团网站周口seo公司
  • 如何对网站做优化温州seo网站建设
  • wordpress网站存放在万网的app叫什么
  • 创意合肥网站建设网站内容优化关键词布局
  • wordpress手机不方便seo推广公司价格
  • 平湖市网站建设seo sem推广
  • 怎么用文件做网站网站开发建站
  • 为澳门赌场做网站维护seo网络优化平台
  • 信誉好的顺德网站建设最新消息
  • 备案ip 查询网站查询网站seo外包如何
  • 申通物流的网站建设搜索引擎调价平台哪个好
  • 有一个专门做lol同人的网站seo伪原创工具
  • 都有哪些做二手挖机的网站建设网站制作
  • 可以做兼职的网站美食软文300范例
  • 做网站新乡友链交易交易平台
  • 新品发布会朋友圈文案手机seo排名
  • 郑州企业网站推广专业seo优化推广
  • 自己怎么建设一个网站六六seo基础运营第三讲
  • 手机微信登入网站淘宝关键词搜索量查询
  • 网站后台无法编辑文字搜索引擎优化解释
  • 建设一个自己的网站首页在线外链工具
  • 好的门户网站爱站网关键词密度查询
  • 阳泉市住房保障和城乡建设管理局网站nba最新新闻
  • 简单的网页案例windows系统优化软件排行榜