695. 岛屿的最大面积

cpp 复制代码
class Solution {
public:
    int dir[4][2]={1,0,0,1,-1,0,0,-1};
    int ans=0;
    void bfs(vector<vector<bool> >&flag,int x,int y,vector<vector<int>>& grid){
        queue<pair<int,int> >q;
        q.push({x,y});
        flag[x][y]=true;
        int cnt=0;
        cnt++;
        while(!q.empty()){
            pair<int,int>p=q.front();
            q.pop();
            int nx=p.first;
            int ny=p.second;
            for(int i=0;i<4;i++){
                int xx=nx+dir[i][0];
                int yy=ny+dir[i][1];
                if(xx<0||yy<0||xx>=grid.size()||yy>=grid[0].size())continue;
                if(flag[xx][yy]==false&&grid[xx][yy]==1){
                    q.push({xx,yy});
                    flag[xx][yy]=true;
                    cnt++;
                }
            }
        }
        if(cnt>ans)ans=cnt;
    }
    int maxAreaOfIsland(vector<vector<int>>& grid) {
        int n=grid.size();
        int m=grid[0].size();
        vector<vector<bool> >flag=vector<vector<bool> >(n,vector<bool>(m,false));
        for(int i=0;i<n;i++){
            for(int j=0;j<m;j++){
                if(grid[i][j]==1&&flag[i][j]==false){
                    bfs(flag,i,j,grid);
                }
            }
        }
        return ans;
    }
};
相关推荐
Samuel-Gyx2 分钟前
数据结构--二叉树构造与遍历顺序的相互转化
数据结构
努力学算法的蒟蒻7 分钟前
day17(11.18)——leetcode面试经典150
算法·leetcode·面试
缘友一世12 分钟前
模型微调DPO算法原理深入学习和理解
算法·模型微调·dpo
未若君雅裁17 分钟前
斐波那契数列 - 动态规划实现 详解笔记
java·数据结构·笔记·算法·动态规划·代理模式
断剑zou天涯18 分钟前
【算法笔记】从暴力递归到动态规划(三)
java·算法·动态规划
RQ_ghylls18 分钟前
2.excel每3行计算一个均值,将高于均值的单元格设置背景红色
算法·均值算法·word·excel
断剑zou天涯21 分钟前
【算法笔记】从暴力递归到动态规划(一)
java·算法·动态规划
不爱编程爱睡觉24 分钟前
代码随想录算法训练营第二十八天 | 动态规划算法基础、 LeetCode509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯
算法·leetcode·动态规划·代码随想录
这张生成的图像能检测吗1 小时前
(论文速读)多任务深度学习框架下基于Lamb波的多损伤数据集构建与量化算法
人工智能·深度学习·算法·数据集·结构健康监测
晨非辰4 小时前
数据结构排序系列指南:从O(n²)到O(n),计数排序如何实现线性时间复杂度
运维·数据结构·c++·人工智能·后端·深度学习·排序算法