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

算法---动态规划练习-6(地下城游戏)

地下城游戏

  • 1. 题目解析
  • 2. 讲解算法原理
  • 3. 编写代码

1. 题目解析

题目地址:点这里

在这里插入图片描述

2. 讲解算法原理

在这里插入图片描述

在这里插入图片描述


  1. 首先,定义一个二维数组 dp,其中 dp[i][j] 表示从位置 (i, j) 开始到达终点时的最低健康点数。

  2. 初始化数组 dp 的边界条件

  • 对于最后一行,即 dp[m-1][j](其中 m 是行数),表示最后一行的每个位置到达终点时的最低健康点数。由于只能向右移动,所以从最后一行的任意位置出发都必须向右移动到达终点,因此初始化为 1。
  • 对于最后一列,即 dp[i][n-1](其中 n 是列数),表示最后一列的每个位置到达终点时的最低健康点数。由于只能向下移动,所以从最后一列的任意位置出发都必须向下移动到达终点,因此初始化为 1
  1. 初始化除了最后一行和最后一列之外的其他位置 dp[i][j] 的值为正无穷大(INT_MAX),表示无法到达终点。

  2. 从倒数第二行开始,从右往左,从下往上遍历整个地牢。对于每个位置 (i, j),计算到达终点的最低健康点数:

  • 使用状态转移方程 dp[i][j] = min(dp[i][j+1], dp[i+1][j]) - dungeon[i][j],表示选择向右移动和向下移动中所需最低健康点数较小的那个,并减去当前位置的健康点数消耗
  • 对于 dp[i][j] 的值,还需要确保其不会小于 1,因为健康点数不能为负数
  1. 最后,返回 dp[0][0],即起点位置的最低健康点数。

3. 编写代码

class Solution {
public://状态表示:以i位置为起点,到达终点时的最低健康点数(此题以i位置为结尾解不出来!!!)int calculateMinimumHP(vector<vector<int>>& dungeon) {int m=dungeon.size();int n=dungeon[0].size();vector<vector<int>> dp(m+1,vector<int>(n+1));dp[m-1][n]=1,dp[m][n-1]=1;for(int i=0;i<n-1;i++) dp[m][i]=INT_MAX;for(int j=0;j<m-1;j++) dp[j][n]=INT_MAX;for(int i=m-1;i>=0;i--){for(int j=n-1;j>=0;j--){//状态转移方程!!!!dp[i][j]=min(dp[i][j+1],dp[i+1][j])-dungeon[i][j];dp[i][j]=max(1,dp[i][j]);}}return dp[0][0];}
};

相关文章:

  • ​马来语翻译中文去哪比较好?
  • 反序列化动态调用 [NPUCTF2020]ReadlezPHP1
  • Redis 特性,为什么要用Redis,Redis到底是多线程还是单线程
  • 如何使用 ArcGIS Pro 制作三维建筑
  • Spring和Spring Boot之间的区别
  • 非wpf应用程序项目【类库、用户控件库】中使用HandyControl
  • IDEA设置内存大小不生效
  • 二、数据库管理员密码管理
  • CSS及javascript
  • Oracle AI Vector Search Multi-Vector Similarity Search 即多向量相似度检索学习笔记
  • 解决PATH变量污染的问题
  • 银河麒麟服务器操作系统V10SP1在登录界面显示启动会话失败
  • 2024蓝桥杯每日一题(背包)
  • 通过多选按钮选择需要修改什么字段
  • 【Django学习笔记(一)】HTML语言简介和基于Flask Web框架快速搭建网站
  • 【技术性】Search知识
  • 【刷算法】从上往下打印二叉树
  • 002-读书笔记-JavaScript高级程序设计 在HTML中使用JavaScript
  • 2017-09-12 前端日报
  • 2017届校招提前批面试回顾
  • canvas绘制圆角头像
  • css布局,左右固定中间自适应实现
  • Docker: 容器互访的三种方式
  • Flex布局到底解决了什么问题
  • hadoop集群管理系统搭建规划说明
  • js面向对象
  • Kibana配置logstash,报表一体化
  • Linux编程学习笔记 | Linux IO学习[1] - 文件IO
  • log4j2输出到kafka
  • SpringCloud(第 039 篇)链接Mysql数据库,通过JpaRepository编写数据库访问
  • Storybook 5.0正式发布:有史以来变化最大的版本\n
  • Zsh 开发指南(第十四篇 文件读写)
  • 服务器从安装到部署全过程(二)
  • 开放才能进步!Angular和Wijmo一起走过的日子
  • 罗辑思维在全链路压测方面的实践和工作笔记
  • 如何胜任知名企业的商业数据分析师?
  • 小程序测试方案初探
  • 写代码的正确姿势
  • 用简单代码看卷积组块发展
  • (LeetCode C++)盛最多水的容器
  • (Ruby)Ubuntu12.04安装Rails环境
  • (TOJ2804)Even? Odd?
  • (笔试题)分解质因式
  • (附程序)AD采集中的10种经典软件滤波程序优缺点分析
  • (个人笔记质量不佳)SQL 左连接、右连接、内连接的区别
  • (论文阅读32/100)Flowing convnets for human pose estimation in videos
  • (十)【Jmeter】线程(Threads(Users))之jp@gc - Stepping Thread Group (deprecated)
  • (续)使用Django搭建一个完整的项目(Centos7+Nginx)
  • (转)http协议
  • *_zh_CN.properties 国际化资源文件 struts 防乱码等
  • ..回顾17,展望18
  • .bat批处理(六):替换字符串中匹配的子串
  • .NET : 在VS2008中计算代码度量值
  • .NET Core中的去虚
  • .NET LINQ 通常分 Syntax Query 和Syntax Method