【剑斩OFFER】算法的暴力美学——LeetCode 200 题:岛屿数量

一、题目描述

二、算法原理

思路:使用 BFS 算法

这道题目是基于:https://blog.csdn.net/2403_84958571/article/details/157102131?spm=1011.2415.3001.10575&sharefrom=mp_manage_link

图形化渲染的题目来的,因为图形化显然遍历上下左右时,将遍历的值修改了,所以不会重复遍历,所以:我们只要补充一下这道题:我们也弄出一个二维数组,大小跟题目给的一样,但是这里面存储的值为:bool 值,我们初始化时将他初始化为 fasle,代表未查找过的岛屿,如果我们使用 BFS 算法查找时,要将遍历过的值变成:true ,代表查找过了;

三、代码实现

cpp 复制代码
class Solution {
    int dy[4] = {0,0,1,-1};
    int dx[4] = {1,-1,0,0};
    typedef pair<int,int> PII;
    void checkgrid(queue<PII>& que,vector<vector<bool>>& tmp,vector<vector<char>>& grid)
    {
        while(que.size())//BFS 算法
        {
            auto [x,y] = que.front();
            que.pop();
            tmp[x][y] = true;
            for(int i = 0; i < 4; i++)
            {
                int a = x + dy[i];
                int b = y + dx[i];
                if(a >= 0 && a < tmp.size() && b >= 0 && b < tmp[0].size() && grid[a][b] == '1' && tmp[a][b] == false)
                {
                    tmp[a][b] = true;
                    que.push({a,b});
                }
            }
        }
    }
public:
    int numIslands(vector<vector<char>>& grid) {

        vector<vector<bool>> tmp(grid.size(),vector<bool>(grid[0].size(),false));//模拟遍历过的数组
        int x = grid[0].size();
        int y = grid.size();
        queue<PII> que;
        int size = 0;//岛屿个数

        for(int i = 0;i < y; i++)//遍历数组,找到未遍历过的岛屿,即:false
        {
            for(int k = 0; k < x;k++)
            {
                if(grid[i][k] == '1' && tmp[i][k] == false)
                {
                    que.push({i,k});
                    size++;
                    checkgrid(que,tmp,grid);
                }
            }
        }
        return size;
    }
};
相关推荐
DeepModel1 小时前
【概率分布】Beta分布详解
算法·概率论
我命由我123451 小时前
React - 验证 Diffing 算法、key 的作用
javascript·算法·react.js·前端框架·html·html5·js
Eward-an5 小时前
LeetCode 1980 题通关指南|3种解法拆解“找唯一未出现二进制串”问题,附Python最优解实现
python·算法·leetcode
程序员酥皮蛋5 小时前
hot 100 第四十题 40.二叉树的层序遍历
数据结构·算法·leetcode
木斯佳6 小时前
HarmonyOS 6实战:从爆款vlog探究鸿蒙智能体提取关键帧算法
算法·华为·harmonyos
Mr.朱鹏7 小时前
JVM-GC垃圾回收案例
java·jvm·spring boot·算法·spring·spring cloud·java-ee
WJSKad12357 小时前
【DepthPro】实战教程:单目深度估计算法详解与应用
算法
wzqllwy7 小时前
8 大经典排序算法(Java 实现):原理 + Demo + 核心分析
java·算法·排序算法
We་ct7 小时前
LeetCode 77. 组合:DFS回溯+剪枝,高效求解组合问题
开发语言·前端·算法·leetcode·typescript·深度优先·剪枝
重生之我是Java开发战士7 小时前
【递归、搜索与回溯】二叉树中的深度优先搜索:布尔二叉树,求根节点到叶节点数字之和,二叉树剪枝,验证二叉搜索树,第K小的元素,二叉树的所有路径
算法·深度优先·剪枝