题解 | #岛屿数量#

岛屿数量

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

import java.util.*;


public class Solution {
    /**
     * 判断岛屿数量
     * @param grid char字符型二维数组
     * @return int整型
     */
    public int solve(char[][] grid) {
        // write code here
        int column = grid.length, line = grid[0].length;
        int ans = 0;
        boolean[][] isVisited = new boolean[column][line];
        for (int i = 0; i < column; i++) {
            for (int j = 0; j < line; j++) {
                if (!isVisited[i][j] && grid[i][j] == '1') {
                    ans++;
                    DFS2(grid, isVisited, i, j);
                }
            }
        }
        return ans;
    }

    public void DFS2(char[][] grid, boolean[][] isVisited, int x, int y) {
        if (x < 0 || x >= grid.length || y < 0 || y >= grid[0].length ||
                grid[x][y] == '0' || isVisited[x][y]) {
            return;
        } else {
            isVisited[x][y] = true;
            DFS2(grid, isVisited, x + 1, y);
            DFS2(grid, isVisited, x - 1, y);
            DFS2(grid, isVisited, x, y + 1);
            DFS2(grid, isVisited, x, y - 1);
        }

    }
}

全部评论

相关推荐

小鹏、大疆、米哈游、MinMax小鹏上午投的下午就约面,进度未免也太快了
蛇年行大运fff:哥们 盗贴有意思吗,我发xhs上的给你搬过来了😅😅😅
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-18 18:23
点赞 评论 收藏
分享
05-30 12:03
山西大学 C++
offer来了我跪着...:不是骗子,等到测评那一步就知道为啥这么高工资了
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务