1
0
mirror of https://gitee.com/coder-xiaomo/leetcode-problemset synced 2025-01-10 18:48:13 +08:00
Code Issues Projects Releases Wiki Activity GitHub Gitee
leetcode-problemset/leetcode-cn/problem (Chinese)/自行车炫技赛场 [kplEvH].md
2022-03-29 12:43:11 +08:00

1.5 KiB
Raw Blame History

「力扣挑战赛」中 N*M 大小的自行车炫技赛场的场地由一片连绵起伏的上下坡组成,场地的高度值记录于二维数组 terrain 中,场地的减速值记录于二维数组 obstacle 中。

  • 若选手骑着自行车从高度为 h1 且减速值为 o1 的位置到高度为 h2 且减速值为 o2 的相邻位置(上下左右四个方向),速度变化值为 h1-h2-o2(负值减速,正值增速)。

选手初始位于坐标 position 处且初始速度为 1请问选手可以刚好到其他哪些位置时速度依旧为 1。请以二维数组形式返回这些位置。若有多个位置则按行坐标升序排列若有多个位置行坐标相同则按列坐标升序排列。

注意: 骑行过程中速度不能为零或负值

示例 1

输入position = [0,0], terrain = [[0,0],[0,0]], obstacle = [[0,0],[0,0]]

输出:[[0,1],[1,0],[1,1]]

解释: 由于当前场地属于平地,根据上面的规则,选手从[0,0]的位置出发都能刚好在其他处的位置速度为 1。

示例 2

输入position = [1,1], terrain = [[5,0],[0,6]], obstacle = [[0,6],[7,0]]

输出:[[0,1]]

解释: 选手从 [1,1] 处的位置出发,到 [0,1] 处的位置时恰好速度为 1。

提示:

  • n == terrain.length == obstacle.length
  • m == terrain[i].length == obstacle[i].length
  • 1 <= n <= 100
  • 1 <= m <= 100
  • 0 <= terrain[i][j], obstacle[i][j] <= 100
  • position.length == 2
  • 0 <= position[0] < n
  • 0 <= position[1] < m