【剑斩OFFER】算法的暴力美学——力扣 1020 题:飞地的数量

一、题目描述

二、算法原理

思路:使用 BFS 算法先处理边界 1 ,再使用 BFS 统计陆地,体现正难则反的思想;

例如:

1)创建一个二维数组来专门标记是否入过队列或者说遍历过;

2)使用 BFS 算法标记边界为 1 的情况;

3)此时整个只有中间被0围起来的1为陆地;

三、代码实现

cpp 复制代码
class Solution {
    int dx[4] = {1,-1,0,0};
    int dy[4] = {0,0,-1,1};
    typedef pair<int,int> PII;
    int n,m;
public:
    int numEnclaves(vector<vector<int>>& grid) {
        n = grid.size();
        m = grid[0].size();
        vector<vector<bool>> vis(grid.size(),vector<bool>(grid[0].size(),false));//标记遍历过的数组

        for(int i = 0; i < m; i++)//处理边界1
        {
            Bfs(0,i,grid,vis);
            Bfs(n - 1,i,grid,vis);
        }
        for(int i = 0; i < n; i++)//处理边界1
        {
            Bfs(i,0,grid,vis);
            Bfs(i,m - 1,grid,vis);
        }

        int ret = 0;

        for(int i = 0; i < n; i++)//此时中间的 1 就是陆地
        {
            for(int j = 0; j < m; j++)
            {
                if(vis[i][j] == false && grid[i][j])
                {
                    ret += Bfs(i,j,grid,vis);
                }
            }
        }
        return ret;
    }
    int Bfs(int i,int j,vector<vector<int>>& grid,vector<vector<bool>>& vis)//BFS 算法
    {
        if(grid[i][j] != 1 || vis[i][j] != false) return 0;

        queue<PII> que;
        que.push({i,j});
        vis[i][j] = true;
        int count = 1;
        while(que.size())
        {
            auto [x,y] = que.front();
            que.pop();
            for(int v = 0; v < 4; v++)
            {
                int a = x + dx[v];
                int b = y + dy[v];
                if(a >= 0 && a < n && b >= 0 && b < m && vis[a][b] == false && grid[a][b] == 1)
                {
                    vis[a][b] = true;
                    que.push({a,b});
                    count++;
                }
            }
        }
        return count;
    }
};
相关推荐
2401_8920709820 小时前
【Linux C++ 日志系统实战】LogFile 日志文件管理核心:滚动策略、线程安全与方法全解析
linux·c++·日志系统·日志滚动
yuzhuanhei20 小时前
Visual Studio 配置C++opencv
c++·学习·visual studio
小O的算法实验室20 小时前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
‎ദ്ദിᵔ.˛.ᵔ₎20 小时前
LIST 的相关知识
数据结构·list
不爱吃炸鸡柳21 小时前
C++ STL list 超详细解析:从接口使用到模拟实现
开发语言·c++·list
M--Y21 小时前
Redis常用数据类型
数据结构·数据库·redis
十五年专注C++开发21 小时前
RTTR: 一款MIT 协议开源的 C++ 运行时反射库
开发语言·c++·反射
‎ദ്ദിᵔ.˛.ᵔ₎21 小时前
STL 栈 队列
开发语言·c++
2401_8920709821 小时前
【Linux C++ 日志系统实战】高性能文件写入 AppendFile 核心方法解析
linux·c++·日志系统·文件写对象
郭涤生21 小时前
STL vector 扩容机制与自定义内存分配器设计分析
c++·算法