图论

图论

是什么???

感觉好神秘啊

我也不知道

但是

应该是一种神秘的数据结构吧!

(我还没学离散数学 先摆了! 虽然好像没什么关系 但是先摆了!)

200.岛屿数量

如图

深度优先算法和广度优先算法

应该蛮好理解的吧…

DFS解法

深度优先搜索

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
class Solution {
public:
int m,n;
void dfs(vector<vector<char>>& grid,int x,int y){
if(x<0||x>=m||y<0||y>=n||grid[x][y]=='0') return; //越界 or 遇到水 直接停
grid[x][y] = '0'; //把当前陆地淹掉
dfs(grid,x+1,y);
dfs(grid,x-1,y); //四个方向递归
dfs(grid,x,y+1);
dfs(grid,x,y-1);
}
int numIslands(vector<vector<char>>& grid) {
m = grid.size();
n = grid[0].size();
int count = 0;
for(int i = 0; i < m; i++){
for(int j = 0; j < n; j++){
if(grid[i][j] == '1'){
count++; //发现一个新岛
dfs(grid,i,j); //淹掉整个岛屿
}
}
}
return count;
}
};

BFS解法

广度优先搜索

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
class Solution {
public:
int numIslands(vector<vector<char>>& grid) {
int m = grid.size();
int n = grid[0].size();
int count = 0;
int dx[4] = {0, 0, 1, -1};
int dy[4] = {1, -1, 0, 0};
queue<pair<int, int>> q; //队列
for (int i = 0; i < m; i++) {
for (int j = 0; j < n; j++) {
if (grid[i][j] == '1') {
count++;
grid[i][j] = '0';
q.push({i, j});
while (!q.empty()) {
auto [x, y] = q.front();
q.pop();
for (int k = 0; k < 4; k++) {
int nx = x + dx[k];
int ny = y + dy[k];
if (nx >= 0 && nx < m && ny >= 0 && ny < n &&
grid[nx][ny] == '1') {
grid[nx][ny] = '0';
q.push({nx, ny});
}
}
}
}
}
}
return count;
}
};

图论
https://roxy5201314.github.io/2026/01/19/图论/
作者
roxy
发布于
2026年1月19日
更新于
2026年3月6日
许可协议