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;
    }
};
相关推荐
猿来不是梦15 分钟前
RT_Thread内核源码分析(五)——内存管理@小堆内存管理算法
stm32·单片机·算法·系统架构·rt_thread操作系统
2401_8812444037 分钟前
vector的用法
算法
W说编程1 小时前
算法导论第三章:数据结构艺术与高效实现
c语言·数据结构·算法
hn小菜鸡1 小时前
LeetCode 2529.正整数和负整数的最大计数
java·算法·leetcode
灏瀚星空1 小时前
高频交易技术:订单簿分析与低延迟架构——从Level 2数据挖掘到FPGA硬件加速的全链路解决方案
人工智能·python·算法·信息可视化·fpga开发·架构·数据挖掘
hn小菜鸡1 小时前
LeetCode 2917.找出数组中的K-or值
数据结构·算法·leetcode
Once_day2 小时前
代码训练LeetCode(34)文本左右对齐
算法·leetcode·c
zhuiQiuMX2 小时前
SQL力扣
数据库·sql·leetcode
tony3652 小时前
强化学习 A2C算法
人工智能·算法
Tess_Blingbling2 小时前
力扣Hoot100 第一天 | 哈希3题
leetcode·哈希算法·散列表