题目描述
周末小明准备去爬山锻炼,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),
【华为OD机试】周末爬山 (C++ Python Java)2023 B卷
于 2023-08-01 21:17:31 首次发布