【DFS】200.岛屿数量
2023-12-15 12:52:35
法1:岛屿数量
class Solution {
public int numIslands(char[][] grid) {
int m = grid.length, n = grid[0].length;
int[][] used = new int[m][n];
int res = 0;
for (int i = 0; i < m; ++i) {
for (int j = 0; j < n; ++j) {
if (grid[i][j] == '0' || used[i][j] == 1) {
continue;
}
++res;
dfs(i, j, grid, used, m, n);
}
}
return res;
}
public void dfs(int i, int j, char[][] grid, int[][] used, int m, int n) {
if (i < 0 || i >= m
|| j < 0 || j >= n
|| grid[i][j] == '0' || used[i][j] == 1) {
return;
}
used[i][j] = 1;
dfs(i - 1, j, grid, used, m, n);
dfs(i + 1, j, grid, used, m, n);
dfs(i, j - 1, grid, used, m, n);
dfs(i, j + 1, grid, used, m, n);
}
}
文章来源:https://blog.csdn.net/Allenlzcoder/article/details/135013468
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!