优选算法_岛屿的最大面积_floodfill算法_C++

一.题目解析

一个群岛在一片海上,找出面积最大的岛屿,如图,红色区域最大

算法解析:floodfill算法+bfs

遍历整个数组,每次遍历到一个新岛屿边缘,用bfs遍历看岛屿的面积有多大,并且将未遍历的位置vis[x][y]=true;

考验代码能力,结合代码进行理解

二.代码编写

cpp 复制代码
class Solution {
    int dx[4]={0,0,1,-1};//方向偏移数组
    int dy[4]={1,-1,0,0};
    bool vis[50][50];//判断是否遍历的数组
    int m,n;
public:
    int maxAreaOfIsland(vector<vector<int>>& grid) {
        m=grid.size(),n=grid[0].size();
        memset(vis, 0, sizeof(vis)); // 初始化 vis
        int ret=0;
        for(int i=0;i<m;i++)//遍历整个数组    
        {
            for(int j=0;j<n;j++)
            {
                if(grid[i][j]==1&&vis[i][j]==false)ret=max(bfs(grid,i,j),ret);
                //满足固定性质并且是没有遍历过的位置
            }
        }
        return ret;
    }

    int bfs(vector<vector<int>>& grid,int i,int j)//bfs看数组的大小
    {
        queue<pair<int,int>>q;//队列实现bfs
        q.push({i,j});
        vis[i][j]=true;//将已经遍历的位置标记
        int curret=1;
        while(!q.empty())
        {   
            auto [a,b]=q.front();
            q.pop();
            for(int k=0;k<4;k++)//四个方向遍历
            {
                int x=a+dx[k],y=b+dy[k];
                if(x>=0&&x<m&&y>=0&&y<n&&grid[x][y]==1&&vis[x][y]==false)curret++,q.push({x,y}),vis[x][y]=true;
                //不越界,满足某一性质,没有遍历的位置
            }
        }
        return curret;//返回当前岛屿大小
    }
};
相关推荐
萝卜白菜。几秒前
TongWeb7.0相同的类指明加载顺序
开发语言·python·pycharm
wb043072011 分钟前
使用 Java 开发 MCP 服务并发布到 Maven 中央仓库完整指南
java·开发语言·spring boot·ai·maven
Rsun045512 分钟前
设计模式应该怎么学
java·开发语言·设计模式
汀、人工智能6 分钟前
[特殊字符] 第2课:字母异位词分组
数据结构·算法·链表·数据库架构··字母异位词分组
Tanecious.12 分钟前
蓝桥杯备赛:Day3-P1918 保龄球
c++·蓝桥杯
良木生香19 分钟前
【C++初阶】:C++类和对象(下):构造函数promax & 类型转换 & static & 友元 & 内部类 & 匿名对象 & 超级优化
c语言·开发语言·c++
5系暗夜孤魂24 分钟前
系统越复杂,越需要“边界感”:从 Java 体系理解大型工程的可维护性本质
java·开发语言
二月夜38 分钟前
Spring循环依赖深度解析:从三级缓存原理到跨环境“灵异”现象
java·spring
小O的算法实验室39 分钟前
2026年SEVC,面向主动成像卫星任务规划问题的群体智能与动态规划混合框架,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
网安INF1 小时前
数据结构第一章复习:基本概念与算法复杂度分析
数据结构·算法