g1501_1600.s1559_detect_cycles_in_2d_grid.Solution Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of leetcode-in-java21 Show documentation
Show all versions of leetcode-in-java21 Show documentation
Java-based LeetCode algorithm problem solutions, regularly updated
package g1501_1600.s1559_detect_cycles_in_2d_grid;
// #Medium #Array #Depth_First_Search #Breadth_First_Search #Matrix #Union_Find
// #2022_04_11_Time_22_ms_(82.51%)_Space_135.8_MB_(70.24%)
/**
* 1559 - Detect Cycles in 2D Grid\.
*
* Medium
*
* Given a 2D array of characters `grid` of size `m x n`, you need to find if there exists any cycle consisting of the **same value** in `grid`.
*
* A cycle is a path of **length 4 or more** in the grid that starts and ends at the same cell. From a given cell, you can move to one of the cells adjacent to it - in one of the four directions (up, down, left, or right), if it has the **same value** of the current cell.
*
* Also, you cannot move to the cell that you visited in your last move. For example, the cycle `(1, 1) -> (1, 2) -> (1, 1)` is invalid because from `(1, 2)` we visited `(1, 1)` which was the last visited cell.
*
* Return `true` if any cycle of the same value exists in `grid`, otherwise, return `false`.
*
* **Example 1:**
*
* **![](https://assets.leetcode.com/uploads/2020/07/15/1.png)**
*
* **Input:** grid = \[\["a","a","a","a"],["a","b","b","a"],["a","b","b","a"],["a","a","a","a"]]
*
* **Output:** true
*
* **Explanation:** There are two valid cycles shown in different colors in the image below: ![](https://assets.leetcode.com/uploads/2020/07/15/11.png)
*
* **Example 2:**
*
* **![](https://assets.leetcode.com/uploads/2020/07/15/22.png)**
*
* **Input:** grid = \[\["c","c","c","a"],["c","d","c","c"],["c","c","e","c"],["f","c","c","c"]]
*
* **Output:** true
*
* **Explanation:** There is only one valid cycle highlighted in the image below: ![](https://assets.leetcode.com/uploads/2020/07/15/2.png)
*
* **Example 3:**
*
* **![](https://assets.leetcode.com/uploads/2020/07/15/3.png)**
*
* **Input:** grid = \[\["a","b","b"],["b","z","b"],["b","b","a"]]
*
* **Output:** false
*
* **Constraints:**
*
* * `m == grid.length`
* * `n == grid[i].length`
* * `1 <= m, n <= 500`
* * `grid` consists only of lowercase English letters.
**/
public class Solution {
public boolean containsCycle(char[][] grid) {
int n = grid.length;
int m = grid[0].length;
boolean[][] visited = new boolean[n + 1][m + 1];
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
if (!visited[i][j] && cycle(grid, i, j, visited, grid[i][j])) {
return true;
}
}
}
return false;
}
private boolean cycle(char[][] grid, int i, int j, boolean[][] visited, char cc) {
if (i < 0 || j < 0 || i >= grid.length || j >= grid[0].length || grid[i][j] != cc) {
return false;
}
if (visited[i][j]) {
return true;
}
visited[i][j] = true;
char temp = grid[i][j];
grid[i][j] = '*';
boolean ans =
cycle(grid, i + 1, j, visited, cc)
|| cycle(grid, i - 1, j, visited, cc)
|| cycle(grid, i, j + 1, visited, cc)
|| cycle(grid, i, j - 1, visited, cc);
grid[i][j] = temp;
return ans;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy