题解 | #岛屿数量#

岛屿数量

http://www.nowcoder.com/practice/0c9664d1554e466aa107d899418e814e

import java.util.*;

public class Solution { /** * 判断岛屿数量 * @param grid char字符型二维数组 * @return int整型 */ public int solve (char[][] grid) { // write code here if (grid == null || grid.length == 0) return 0; //统计岛屿的个数 int count = 0; //两个for循环遍历每一个格子 for (int i = 0; i < grid.length; i++) for (int j = 0; j < grid[0].length; j++) { //只有当前格子是1才开始计算 if (grid[i][j] == '1') { //如果当前格子是1,岛屿的数量加1 count++; //然后通过dfs把当前格子的上下左右4 //个位置为1的都要置为0,因为他们是连着 //一起的算一个岛屿, dfs(grid, i, j); } } //最后返回岛屿的数量 return count; } public void dfs(char[][] grid, int i, int j) { //边界条件判断,不能越界 if (i < 0 || i >= grid.length || j < 0 || j >= grid[0].length || grid[i][j] == '0') return; //把当前格子置为0,然后再从他的上下左右4个方向继续遍历 grid[i][j] = '0'; dfs(grid, i - 1, j);//上 dfs(grid, i + 1, j);//下 dfs(grid, i, j + 1);//左 dfs(grid, i, j - 1);//右 } }

我居南半坡 文章被收录于专栏

多刷题,积蓄力量,欢迎讨论

全部评论

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务