【剑斩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;
    }
};
相关推荐
兔子77314 小时前
LSTM 终于讲明白了:从“RNN 为什么会忘”到 Hochreiter & Schmidhuber 1997 全文吃透
算法
ECT-OS-JiuHuaShan14 小时前
朱梁万有递归元定理,重构《阴符经》
算法·重构
_日拱一卒14 小时前
LeetCode:最长连续序列
算法·leetcode·职场和发展
2401_8795034114 小时前
C++与FPGA协同设计
开发语言·c++·算法
重生之后端学习14 小时前
287. 寻找重复数
数据结构·算法·leetcode·深度优先·图论
抓个马尾女孩14 小时前
位置编码:绝对位置编码、相对位置编码、旋转位置编码
人工智能·深度学习·算法·transformer
一只小灿灿14 小时前
六大主流编程语言数据类型底层深度解析:从硬件寄存器到内存布局、编译运行与跨平台本质(超全底层版)
数据结构
今儿敲了吗14 小时前
46| FBI树
数据结构·c++·笔记·学习·算法
小辉同志15 小时前
139. 单词拆分
算法·动态规划
oem11015 小时前
C++中的访问者模式变体
开发语言·c++·算法