-
Notifications
You must be signed in to change notification settings - Fork 23
/
Copy path1368-minimum-cost-to-make-at-least-one-valid-path-in-a-grid.js
50 lines (47 loc) · 1.89 KB
/
1368-minimum-cost-to-make-at-least-one-valid-path-in-a-grid.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
/**
* 1368. Minimum Cost to Make at Least One Valid Path in a Grid
* https://leetcode.com/problems/minimum-cost-to-make-at-least-one-valid-path-in-a-grid/
* Difficulty: Hard
*
* Given an 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] to grid[i][j + 1])
* - 2 which means go to the cell to the left. (i.e go from grid[i][j] to grid[i][j - 1])
* - 3 which means go to the lower cell. (i.e go from grid[i][j] to grid[i + 1][j])
* - 4 which means go to the upper cell. (i.e go from grid[i][j] to grid[i - 1][j])
*
* Notice that there could be some signs on the cells of the grid that point outside the grid.
*
* You will initially start at the upper left cell (0, 0). A valid path in the grid is a path
* that 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 does not 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.
*/
/**
* @param {number[][]} grid
* @return {number}
*/
var minCost = function(grid) {
const queue = [[0, 0]];
const directions = [[0, 1, 1], [0, -1, 2], [1, 0, 3], [-1, 0, 4]];
const bfs = grid.map(r => r.map(_ => Infinity));
bfs[0][0] = 0;
while (queue.length > 0) {
const [x, y] = queue.shift();
for (const [dx, dy, value] of directions) {
const [cX, cY] = [x + dx, y + dy];
if (grid[cX]?.[cY]) {
const updatedValue = bfs[x][y] + (grid[x][y] !== value);
if (updatedValue < bfs[cX][cY]) {
bfs[cX][cY] = updatedValue;
queue.push([cX, cY]);
}
}
}
}
return bfs.at(-1).at(-1);
};