Skip to content

Commit 900840b

Browse files
authored
Merge pull request #1060 from julienChemillier/patch-12
Add 130 in c language
2 parents d75dec8 + 58912e6 commit 900840b

File tree

1 file changed

+48
-0
lines changed

1 file changed

+48
-0
lines changed

Diff for: c/130-Surrounded-Regions.c

+48
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,48 @@
1+
/*
2+
Given an m x n matrix board containing 'X' and 'O', capture all regions that are 4-directionally surrounded by 'X'.
3+
Time: O(n^2)
4+
Space: O(1)
5+
*/
6+
7+
8+
void dfsModifyBorder(char** board, int n, int m, int i, int j) {
9+
if (board[i][j]=='X')
10+
return;
11+
board[i][j]='T';
12+
if (i>0 && board[i-1][j]=='O')
13+
dfsModifyBorder(board, n, m, i-1, j);
14+
if (j>0 && board[i][j-1]=='O')
15+
dfsModifyBorder(board, n, m, i, j-1);
16+
if (i<(n-1) && board[i+1][j]=='O')
17+
dfsModifyBorder(board, n, m, i+1, j);
18+
if (j<(m-1) && board[i][j+1]=='O')
19+
dfsModifyBorder(board, n, m, i, j+1);
20+
}
21+
22+
void reModifyBorder(char** board, int n, int m) {
23+
int i, j;
24+
for (i=0; i<n; i++){
25+
for (j=0; j<m; j++){
26+
if (board[i][j]=='O')
27+
board[i][j]='X';
28+
else if (board[i][j]=='T')
29+
board[i][j]='O';
30+
}
31+
}
32+
}
33+
34+
void solve(char** board, int boardSize, int* boardColSize){
35+
int i, j;
36+
int m = (*boardColSize);
37+
int n1 = boardSize-1;
38+
int m1 = m-1;
39+
for (i=1; i<n1; i++) {
40+
dfsModifyBorder(board, boardSize, m, i, 0);
41+
dfsModifyBorder(board, boardSize, m, i, m1);
42+
}
43+
for (j=0; j<m; j++) {
44+
dfsModifyBorder(board, boardSize, m, 0, j);
45+
dfsModifyBorder(board, boardSize, m, n1, j);
46+
}
47+
reModifyBorder(board, boardSize, m);
48+
}

0 commit comments

Comments
 (0)