【华为OD题库-079】周末爬山-Java

2023-12-06 19:20

本文主要是介绍【华为OD题库-079】周末爬山-Java,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目

周末小明准备去爬山锻炼,0代表平地,山的高度使用1到9来表示,小明每次爬山或下山高度只能相差k及k以内,每次只能上下左右一个方向上移动—格,小明从左上角(0,0)位置出发
输入描述
第一行输入m n k(空格分隔)。代表m*n的二维山地图,k为小明每次爬山或下山高度差的最大值
然后接下来输入山地图,一共m行n列,均以空格分隔。
取值范围:
0<m <= 500
0<<=5000<k<5
输出描述
请问小明能爬到的最高峰多高,到该最高峰的最短步数,输出以空格分隔。同高度的山峰输出较短步数.,如果没有可以爬的山峰,则高度和步数都返回0
示例1:
输入
5 4 1
0 1 2 0
1 0 0 0
1 0 1 2
1 3 1 0
0 0 0 9
输出
2 2
说明
根据山地图可知,能爬到的最高峰在(0,2)位置,高度为2,最短路径为(0.0)-(0,1)-(0,2),最短步数为2。
示例2:
输入
5 4 3
0 0 0 0
0 0 0 0
0 9 0 0
0 0 0 0
0 0 0 9
输出说明
0 0
根据山地图可知,每次爬山距离3,无法爬到山峰上,步数为0.

思路

同【华为OD题库-001】宜居星球改造计划

只是在之前的基础上加了一个差值不超过k的限制

题解

package hwod;import java.util.HashMap;
import java.util.LinkedList;
import java.util.Map;
import java.util.Scanner;public class ClimbingMountains {public static void main(String[] args) {Scanner sc = new Scanner(System.in);int m = sc.nextInt();int n = sc.nextInt();int k = sc.nextInt();int[][] nums = new int[m][n];for (int i = 0; i < m; i++) {for (int j = 0; j < n; j++) {nums[i][j] = sc.nextInt();}}int[] res = climbingMountains(nums, k);System.out.println(res[0] + " " + res[1]);}private static int[] x_axis = new int[]{1, 0, -1, 0};private static int[] y_axis = new int[]{0, 1, 0, -1};private static int[] climbingMountains(int[][] nums, int k) {int m = nums.length, n = nums[0].length;int[] used = new int[m * n];LinkedList<Integer> queue = new LinkedList<>();queue.addLast(0);used[0] = 1;int maxHeight = nums[0][0], minStep = 0;Map<Integer, Integer> map = new HashMap<>();while (!queue.isEmpty()) {int cur = queue.removeFirst();int x = cur / n, y = cur % n;for (int i = 0; i < 4; i++) {int new_x = x + x_axis[i], new_y = y + y_axis[i];int newIdx = new_x * n + new_y;//下一个坐标的位置if (new_x >= 0 && new_x < nums.length && new_y >= 0 && new_y < nums[0].length&& used[newIdx] == 0&& Math.abs(nums[new_x][new_y] - nums[x][y]) <= k) {used[newIdx] = 1;queue.addLast(newIdx);map.put(newIdx, map.getOrDefault(cur, 0) + 1);if (nums[new_x][new_y] >= maxHeight) {if (nums[new_x][new_y] == maxHeight) {minStep = Math.min(map.getOrDefault(newIdx, 0), minStep);} else {minStep = map.getOrDefault(newIdx, 0);}maxHeight = nums[new_x][new_y];}}}}return new int[]{maxHeight, minStep};}
}

推荐

如果你对本系列的其他题目感兴趣,可以参考华为OD机试真题及题解(JAVA),查看当前专栏更新的所有题目。

这篇关于【华为OD题库-079】周末爬山-Java的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/463004

相关文章

SpringMVC前后端传值的几种实现方式

《SpringMVC前后端传值的几种实现方式》本文主要介绍了SpringMVC前后端传值的方式实现,包括使用HttpServletRequest、HttpSession、Model和ModelAndV... 目录一、从Controller层到JSP界面1、使用HttpServletRequest的方式2、使

Spring Boot Actuator使用说明

《SpringBootActuator使用说明》SpringBootActuator是一个用于监控和管理SpringBoot应用程序的强大工具,通过引入依赖并配置,可以启用默认的监控接口,... 目录项目里引入下面这个依赖使用场景总结说明:本文介绍Spring Boot Actuator的使用,关于Spri

Java实战之自助进行多张图片合成拼接

《Java实战之自助进行多张图片合成拼接》在当今数字化时代,图像处理技术在各个领域都发挥着至关重要的作用,本文为大家详细介绍了如何使用Java实现多张图片合成拼接,需要的可以了解下... 目录前言一、图片合成需求描述二、图片合成设计与实现1、编程语言2、基础数据准备3、图片合成流程4、图片合成实现三、总结前

SpringBoot定制JSON响应数据的实现

《SpringBoot定制JSON响应数据的实现》本文主要介绍了SpringBoot定制JSON响应数据的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录前言一、如何使用@jsonView这个注解?二、应用场景三、实战案例注解方式编程方式总结 前言

SpringBoot整合DeepSeek实现AI对话功能

《SpringBoot整合DeepSeek实现AI对话功能》本文介绍了如何在SpringBoot项目中整合DeepSeekAPI和本地私有化部署DeepSeekR1模型,通过SpringAI框架简化了... 目录Spring AI版本依赖整合DeepSeek API key整合本地化部署的DeepSeek

Java中基于注解的代码生成工具MapStruct映射使用详解

《Java中基于注解的代码生成工具MapStruct映射使用详解》MapStruct作为一个基于注解的代码生成工具,为我们提供了一种更加优雅、高效的解决方案,本文主要为大家介绍了它的具体使用,感兴趣... 目录介绍优缺点优点缺点核心注解及详细使用语法说明@Mapper@Mapping@Mappings@Co

SpringBoot中的404错误:原因、影响及解决策略

《SpringBoot中的404错误:原因、影响及解决策略》本文详细介绍了SpringBoot中404错误的出现原因、影响以及处理策略,404错误常见于URL路径错误、控制器配置问题、静态资源配置错误... 目录Spring Boot中的404错误:原因、影响及处理策略404错误的出现原因1. URL路径错

Java使用POI-TL和JFreeChart动态生成Word报告

《Java使用POI-TL和JFreeChart动态生成Word报告》本文介绍了使用POI-TL和JFreeChart生成包含动态数据和图表的Word报告的方法,并分享了实际开发中的踩坑经验,通过代码... 目录前言一、需求背景二、方案分析三、 POI-TL + JFreeChart 实现3.1 Maven

使用Java实现获取客户端IP地址

《使用Java实现获取客户端IP地址》这篇文章主要为大家详细介绍了如何使用Java实现获取客户端IP地址,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 首先是获取 IP,直接上代码import org.springframework.web.context.request.Requ

java中不同版本JSONObject区别小结

《java中不同版本JSONObject区别小结》本文主要介绍了java中不同版本JSONObject区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录1. FastjsON2. Jackson3. Gson4. org.json6. 总结在Jav