题目描述
周末小明准备去爬山锻炼,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
0 0 0 0
0 9 0 0
这篇博客介绍了华为在线开发者(OD)机试中的一道Python编程题,题目要求求解在给定的山地图中,小明能爬到的最高峰高度及到达最高峰的最短步数。博主分享了详细的解题思路和代码实现,通过示例解释了输出结果的含义,并指出所有输入均符合题目规定。
订阅专栏 解锁全文
176

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



