目录

floodfill算法系列一>岛屿数量

解析

整体思路:

代码设计:

代码呈现:

java 复制代码
class Solution {
    int m,n,ret;
    boolean[][] vis;

    public int numIslands(char[][] grid) {
        m = grid.length;
        n = grid[0].length;

        vis = new boolean[m][n];
        for(int i = 0; i < m; i++)
            for(int j = 0; j < n; j++){
                if(!vis[i][j] && grid[i][j] == '1'){
                    ret++;
                    //把这个岛屿附近的1标记一下
                    dfs(grid,i,j);
                }
            }

        return ret;    
    }

    int[] dx = {0,0,-1,1};
    int[] dy = {1,-1,0,0};
    private void dfs(char[][] grid, int i, int j){

        vis[i][j] = true;//标记
        for(int k = 0; k < 4; k++){
            int x = i + dx[k]; int y = j + dy[k];
            if(x >= 0 && x < m && y >= 0 && y < n && !vis[x][y] && grid[x][y] == '1'){
                dfs(grid,x,y);
            }
        }

    }
}
本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
随风75639 分钟前
有多少小于当前数字的数字 力扣1365
数据结构·算法·leetcode
今天吃什么了41 分钟前
矩阵幂(矩阵k次幂)
人工智能·算法·矩阵
我叫王棱夹41 分钟前
第五章-动态规划
算法·动态规划
光军oi2 小时前
不像人做的题————十四届蓝桥杯省赛真题解析(上)A,B,C,D题解析
c语言·蓝桥杯·深度优先
dot to one2 小时前
深入刨析C++ stl::stack 、stl::queue 及 priority_queue
c语言·开发语言·数据结构·c++·算法·visual studio
程序趣谈5 小时前
算法随笔_74: 不同路径_1
数据结构·python·算法
修修修也6 小时前
算法手记3
数据结构·学习·算法·刷题
吧啦吧啦吡叭卜7 小时前
【打卡d5】快速排序 归并排序
java·算法·排序算法
L_cl7 小时前
【Python 数据结构 15.哈希表】
数据结构·算法·散列表