From bb2a683a58c1564b411fe0ba9e858adf4d684525 Mon Sep 17 00:00:00 2001 From: 0xff-dev Date: Thu, 17 Oct 2024 09:33:11 +0800 Subject: [PATCH] Add solution and test-cases for problem 1391 --- .../1.png | Bin 0 -> 20864 bytes .../README.md | 54 +++++++++ .../Solution.go | 112 +++++++++++++++++- .../Solution_test.go | 12 +- .../e1.png | Bin 0 -> 14654 bytes .../e2.png | Bin 0 -> 11298 bytes 6 files changed, 170 insertions(+), 8 deletions(-) create mode 100644 leetcode/1301-1400/1391.Check-if-There-is-a-Valid-Path-in-a-Grid/1.png create mode 100644 leetcode/1301-1400/1391.Check-if-There-is-a-Valid-Path-in-a-Grid/README.md create mode 100644 leetcode/1301-1400/1391.Check-if-There-is-a-Valid-Path-in-a-Grid/e1.png create mode 100644 leetcode/1301-1400/1391.Check-if-There-is-a-Valid-Path-in-a-Grid/e2.png diff --git a/leetcode/1301-1400/1391.Check-if-There-is-a-Valid-Path-in-a-Grid/1.png b/leetcode/1301-1400/1391.Check-if-There-is-a-Valid-Path-in-a-Grid/1.png new file mode 100644 index 0000000000000000000000000000000000000000..31d85c6d48034f253843d5cecdf51d14be0f11a7 GIT binary patch literal 20864 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 literal 0 HcmV?d00001 diff --git a/leetcode/1301-1400/1391.Check-if-There-is-a-Valid-Path-in-a-Grid/README.md b/leetcode/1301-1400/1391.Check-if-There-is-a-Valid-Path-in-a-Grid/README.md new file mode 100644 index 00000000..73a6ca15 --- /dev/null +++ b/leetcode/1301-1400/1391.Check-if-There-is-a-Valid-Path-in-a-Grid/README.md @@ -0,0 +1,54 @@ +# [1391. Check if There is a Valid Path in a Grid][title] + +## Description +You are given an `m x n` `grid`. Each cell of `grid` represents a street. The street of `grid[i][j]` can be: + +- `1` which means a street connecting the left cell and the right cell. +- `2` which means a street connecting the upper cell and the lower cell. +- `3` which means a street connecting the left cell and the lower cell. +- `4` which means a street connecting the right cell and the lower cell. +- `5` which means a street connecting the left cell and the upper cell. +- `6` which means a street connecting the right cell and the upper cell. + +![1](./1.png) + +You will initially start at the street of 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)`. **The path should only follow the streets**. + +**Notice** that you are **not allowed** to change any street. + +Return `true` if there is a valid path in the grid or `false` otherwise. + +**Example 1:** + +![e1](./e1.png) + +``` +Input: grid = [[2,4,3],[6,5,2]] +Output: true +Explanation: As shown you can start at cell (0, 0) and visit all the cells of the grid to reach (m - 1, n - 1). +``` + +**Example 2:** + +![e2](./e1.png) + +``` +Input: grid = [[1,2,1],[1,2,1]] +Output: false +Explanation: As shown you the street at cell (0, 0) is not connected with any street of any other cell and you will get stuck at cell (0, 0) +``` + +**Example 3:** + +``` +Input: grid = [[1,1,2]] +Output: false +Explanation: You will get stuck at cell (0, 1) and you cannot reach cell (0, 2). +``` + +## 结语 + +如果你同我一样热爱数据结构、算法、LeetCode,可以关注我 GitHub 上的 LeetCode 题解:[awesome-golang-algorithm][me] + +[title]: https://leetcode.com/problems/check-if-there-is-a-valid-path-in-a-grid +[me]: https://github.com/kylesliu/awesome-golang-algorithm diff --git a/leetcode/1301-1400/1391.Check-if-There-is-a-Valid-Path-in-a-Grid/Solution.go b/leetcode/1301-1400/1391.Check-if-There-is-a-Valid-Path-in-a-Grid/Solution.go index d115ccf5..4393a4a5 100755 --- a/leetcode/1301-1400/1391.Check-if-There-is-a-Valid-Path-in-a-Grid/Solution.go +++ b/leetcode/1301-1400/1391.Check-if-There-is-a-Valid-Path-in-a-Grid/Solution.go @@ -1,5 +1,113 @@ package Solution -func Solution(x bool) bool { - return x +var dirFn = [6]func(int, int, [][]int) [][2]int{ + func(x, y int, grid [][]int) [][2]int { + m, n := len(grid), len(grid[0]) + res := make([][2]int, 0) + + nx, ny := x, y-1 + if !(nx < 0 || nx >= m || ny < 0 || ny >= n) && (grid[nx][ny] == 1 || grid[nx][ny] == 4 || grid[nx][ny] == 6) { + res = append(res, [2]int{nx, ny}) + } + nx, ny = x, y+1 + if !(nx < 0 || nx >= m || ny < 0 || ny >= n) && (grid[nx][ny] == 1 || grid[nx][ny] == 3 || grid[nx][ny] == 5) { + res = append(res, [2]int{nx, ny}) + } + return res + }, + func(x, y int, grid [][]int) [][2]int { + m, n := len(grid), len(grid[0]) + res := make([][2]int, 0) + + nx, ny := x-1, y + if !(nx < 0 || nx >= m || ny < 0 || ny >= n) && (grid[nx][ny] == 2 || grid[nx][ny] == 3 || grid[nx][ny] == 4) { + res = append(res, [2]int{nx, ny}) + } + nx, ny = x+1, y + if !(nx < 0 || nx >= m || ny < 0 || ny >= n) && (grid[nx][ny] == 2 || grid[nx][ny] == 5 || grid[nx][ny] == 6) { + res = append(res, [2]int{nx, ny}) + } + return res + }, + func(x, y int, grid [][]int) [][2]int { + m, n := len(grid), len(grid[0]) + res := make([][2]int, 0) + + nx, ny := x, y-1 + if !(nx < 0 || nx >= m || ny < 0 || ny >= n) && (grid[nx][ny] == 1 || grid[nx][ny] == 4 || grid[nx][ny] == 6) { + res = append(res, [2]int{nx, ny}) + } + nx, ny = x+1, y + if !(nx < 0 || nx >= m || ny < 0 || ny >= n) && (grid[nx][ny] == 2 || grid[nx][ny] == 5 || grid[nx][ny] == 6) { + res = append(res, [2]int{nx, ny}) + } + return res + }, + func(x, y int, grid [][]int) [][2]int { + m, n := len(grid), len(grid[0]) + res := make([][2]int, 0) + + nx, ny := x, y+1 + if !(nx < 0 || nx >= m || ny < 0 || ny >= n) && (grid[nx][ny] == 1 || grid[nx][ny] == 3 || grid[nx][ny] == 5) { + res = append(res, [2]int{nx, ny}) + } + nx, ny = x+1, y + if !(nx < 0 || nx >= m || ny < 0 || ny >= n) && (grid[nx][ny] == 2 || grid[nx][ny] == 5 || grid[nx][ny] == 6) { + res = append(res, [2]int{nx, ny}) + } + return res + }, + func(x, y int, grid [][]int) [][2]int { + m, n := len(grid), len(grid[0]) + res := make([][2]int, 0) + + nx, ny := x, y-1 + if !(nx < 0 || nx >= m || ny < 0 || ny >= n) && (grid[nx][ny] == 1 || grid[nx][ny] == 4 || grid[nx][ny] == 6) { + res = append(res, [2]int{nx, ny}) + } + nx, ny = x-1, y + if !(nx < 0 || nx >= m || ny < 0 || ny >= n) && (grid[nx][ny] == 2 || grid[nx][ny] == 3 || grid[nx][ny] == 4) { + res = append(res, [2]int{nx, ny}) + } + return res + }, + func(x, y int, grid [][]int) [][2]int { + m, n := len(grid), len(grid[0]) + res := make([][2]int, 0) + + nx, ny := x, y+1 + if !(nx < 0 || nx >= m || ny < 0 || ny >= n) && (grid[nx][ny] == 1 || grid[nx][ny] == 3 || grid[nx][ny] == 5) { + res = append(res, [2]int{nx, ny}) + } + nx, ny = x-1, y + if !(nx < 0 || nx >= m || ny < 0 || ny >= n) && (grid[nx][ny] == 2 || grid[nx][ny] == 3 || grid[nx][ny] == 4) { + res = append(res, [2]int{nx, ny}) + } + return res + }, +} + +func Solution(grid [][]int) bool { + m, n := len(grid)-1, len(grid[0])-1 + q := [][2]int{{0, 0}} + v := make(map[[2]int]struct{}) + v[[2]int{0, 0}] = struct{}{} + for len(q) > 0 { + nq := make([][2]int, 0) + for _, pos := range q { + x, y := pos[0], pos[1] + if x == m && y == n { + return true + } + for _, next := range dirFn[grid[x][y]-1](x, y, grid) { + if _, ok := v[next]; ok { + continue + } + nq = append(nq, next) + v[next] = struct{}{} + } + } + q = nq + } + return false } diff --git a/leetcode/1301-1400/1391.Check-if-There-is-a-Valid-Path-in-a-Grid/Solution_test.go b/leetcode/1301-1400/1391.Check-if-There-is-a-Valid-Path-in-a-Grid/Solution_test.go index 14ff50eb..cc517444 100755 --- a/leetcode/1301-1400/1391.Check-if-There-is-a-Valid-Path-in-a-Grid/Solution_test.go +++ b/leetcode/1301-1400/1391.Check-if-There-is-a-Valid-Path-in-a-Grid/Solution_test.go @@ -10,12 +10,12 @@ func TestSolution(t *testing.T) { // 测试用例 cases := []struct { name string - inputs bool + inputs [][]int expect bool }{ - {"TestCase", true, true}, - {"TestCase", true, true}, - {"TestCase", false, false}, + {"TestCase1", [][]int{{2, 4, 3}, {6, 5, 2}}, true}, + {"TestCase2", [][]int{{1, 2, 1}, {1, 2, 1}}, false}, + {"TestCase3", [][]int{{1, 1, 2}}, false}, } // 开始测试 @@ -30,10 +30,10 @@ func TestSolution(t *testing.T) { } } -// 压力测试 +// 压力测试 func BenchmarkSolution(b *testing.B) { } -// 使用案列 +// 使用案列 func ExampleSolution() { } diff --git a/leetcode/1301-1400/1391.Check-if-There-is-a-Valid-Path-in-a-Grid/e1.png b/leetcode/1301-1400/1391.Check-if-There-is-a-Valid-Path-in-a-Grid/e1.png new file mode 100644 index 0000000000000000000000000000000000000000..014fbcba1f2e57a7278ba2b20b4a7e16a79714fc GIT binary patch literal 14654 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 VMMf9fz+5lG+tX)GuKSuV{{gjUtatzb literal 0 HcmV?d00001