题目描述
周末小明准备去爬山锻炼,0代表平地,山的高度使用1到9来表示,
小明每次爬山或下山高度只能相差k及k以内,每次只能上下左右一个方向上移动一格,
小明从左上角(0,0)位置出发
输入描述
第一行输入m n k(空格分隔)。代表m*n的二维山地图,k为小明每次爬山或下山高度差的最大值
然后接下来输入山地图,一共m行n列,均以空格分隔。取值范围:
0< m <= 500
0<n<=500
0<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
【华为OD机试】周末爬山 (C++ Python Java)2023 B卷
于 2023-08-01 21:17:31 首次发布
本文介绍了华为在线开发者(OD)考试中的一道爬山问题,要求在给定的二维地图中,计算小明能够达到的最高峰高度和最短步数。题目限制了每次移动的高度差k,并提供了多个示例进行说明。解决方案可能涉及到BFS搜索算法。
订阅专栏 解锁全文
19万+

被折叠的 条评论
为什么被折叠?



