leetcode-1368-Minimum Cost to Make at Least One Valid Path in a Grid
问题
Given a m x n grid. Each cell of the grid has a sign pointing to the next cell you should visit if you are currently in this cell. The sign of grid[i][j] can be:
- 1 which means go to the cell to the right. (i.e go from
grid[i][j]togrid[i][j + 1]) - 2 which means go to the cell to the left. (i.e go from
grid[i][j]togrid[i][j - 1]) - 3 which means go to the~ lower cell. (i.e go from
grid[i][j]togrid[i + 1][j]) - 4 which means go to the upper cell. (i.e go from
grid[i][j]togrid[i - 1][j])
Notice that there could be some invalid signs on the cells of the grid which points outside the grid.
You will initially start at the upper left cell (0,0). A valid path in the grid is a path which starts from the upper left cell (0,0) and ends at the bottom-right cell (m - 1, n - 1) following the signs on the grid. The valid path doesn’t have to be the shortest.
You can modify the sign on a cell with cost = 1. You can modify the sign on a cell one time only.
Return the minimum cost to make the grid have at least one valid path.
Example 1:

1 | Input: grid = [[1,1,1,1],[2,2,2,2],[1,1,1,1],[2,2,2,2]] |
Example 2:

1 | Input: grid = [[1,1,3],[3,2,2],[1,1,4]] |
Example 3:

1 | Input: grid = [[1,2],[4,3]] |
Example 4:
1 | Input: grid = [[2,2,2],[2,2,2]] |
Example 5:
1 | Input: grid = [[4]] |
Constraints:
m == grid.lengthn == grid[i].length1 <= m, n <= 100
分析
方案一:使用优先队列进行图的搜索,每个节点在出站时被确定所需要的花费。时间复杂度 $O(NMlogNM)$,空间复杂度 $O(NM)$ 。
方案二:使用BFS+DFS,BFS用来按照cost从小到大依次访问节点,DFS用来在层级内进行穿梭,搜索同一层的节点。时间复杂度 $O(NM)$,空间复杂度 $O(NM)$ 。
代码1
1 | // 优先队列 |
代码2
1 | // BFS+DFS |
Author: Hatton.Liu
Link: http://hattonl.github.io/2020/03/03/leetcode-1368/
License: 知识共享署名-非商业性使用 4.0 国际许可协议