Regions Cut By Slashes
Input:
[
" /",
"/ "
]
Output: 2
Explanation: The 2x2 grid is as follows:




Basic Idea:
Java Code:
DFS Solution
Last updated
Input:
[
" /",
"/ "
]
Output: 2
Explanation: The 2x2 grid is as follows:




Last updated
Input:
[
" /",
" "
]
Output: 1
Explanation: The 2x2 grid is as follows:Input:
[
"\\/",
"/\\"
]
Output: 4
Explanation: (Recall that because \ characters are escaped, "\\/" refers to \/, and "/\\" refers to /\.)
The 2x2 grid is as follows:Input:
[
"/\\",
"\\/"
]
Output: 5
Explanation: (Recall that because \ characters are escaped, "/\\" refers to /\, and "\\/" refers to \/.)
The 2x2 grid is as follows:Input:
[
"//",
"/ "
]
Output: 3
Explanation: The 2x2 grid is as follows:class Solution {
private int[] idxs;
private int count;
private int N;
private int left = 0;
private int top = 1;
private int right = 2;
private int down = 3;
private int find(int x) {
if (idxs[x] == x) return x;
else {
idxs[x] = find(idxs[x]);
return idxs[x];
}
}
private void union(int x, int y) {
int rootx = find(x);
int rooty = find(y);
if (rootx == rooty) return;
idxs[rootx] = rooty;
count--;
}
private int genIdx(int r, int c, int pos) {
return (N * r + c) * 4 + pos;
}
public int regionsBySlashes(String[] grid) {
N = grid.length;
idxs = new int[N * N * 4];
for (int i = 0; i < idxs.length; ++i) idxs[i] = i;
count = N * N * 4;
for (int r = 0; r < grid.length; ++r) {
for (int c = 0; c < grid[0].length(); ++c) {
char chr = grid[r].charAt(c);
int topNeighbor = genIdx(r - 1, c, down);
int leftNeighbor = genIdx(r, c - 1, right);
// 先处理相邻正方形之间的三角形,这里我们总是和当前正方向左边上上边相邻部分做union
if (r > 0) union(genIdx(r, c, top), topNeighbor);
if (c > 0) union(genIdx(r, c, left), leftNeighbor);
if (chr == ' ') {
union(genIdx(r, c, left), genIdx(r, c, top));
union(genIdx(r, c, left), genIdx(r, c, right));
union(genIdx(r, c, left), genIdx(r, c, down));
} else if (chr == '/') {
union(genIdx(r, c, left), genIdx(r, c, top));
union(genIdx(r, c, down), genIdx(r, c, right));
} else { // case: '\\'
union(genIdx(r, c, left), genIdx(r, c, down));
union(genIdx(r, c, top), genIdx(r, c, right));
}
}
}
return count;
}
}/*
[][][] 1[][] [][]1
[][][] or []1[] or []1[] dfs
[][][] [][]1 1[][]
*/
class Solution {
private int[] dr = {0, 1, -1, 0}, dc = {1, 0, 0, -1};
private boolean[][] mGrid; // true==>1, false==>0
private int M;
public int regionsBySlashes(String[] grid) {
M = grid.length;
mGrid = new boolean[M * 3][M * 3];
for (int i = 0; i < M; ++i) {
for (int j = 0; j < M; ++j) {
char c = grid[i].charAt(j);
if (c == '\\') {
mGrid[i * 3][j * 3] = true;
mGrid[i * 3 + 1][j * 3 + 1] = true;
mGrid[i * 3 + 2][j * 3 + 2] = true;
} else if (c == '/') {
mGrid[i * 3][j * 3 + 2] = true;
mGrid[i * 3 + 1][j * 3 + 1] = true;
mGrid[i * 3 + 2][j * 3] = true;
}
}
}
int ret = 0;
for (int i = 0; i < 3 * M; ++i) {
for (int j = 0; j < 3 * M; ++j) {
if (!mGrid[i][j]) {
dfs(i, j);
ret++;
}
}
}
return ret;
}
private void dfs(int r, int c) {
if (mGrid[r][c]) return;
mGrid[r][c] = true;
for (int i = 0; i < 4; ++i) {
int nr = r + dr[i], nc = c + dc[i];
if (nr >= 0 && nr < M * 3 && nc >= 0 && nc < M * 3) {
dfs(nr, nc);
}
}
}
}