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;
    }
};
相关推荐
岛雨QA26 分钟前
递归「Java数据结构与算法学习笔记5」
数据结构·算法
kebijuelun29 分钟前
Learning Personalized Agents from Human Feedback:用人类反馈训练可持续个性化智能体
人工智能·深度学习·算法·transformer
Eloudy38 分钟前
稀疏矩阵的 CSR 格式(Compressed Sparse Row)
人工智能·算法·arch·hpc
岛雨QA43 分钟前
栈「Java数据结构与算法学习笔记4」
数据结构·算法
乐观勇敢坚强的老彭1 小时前
c++寒假营day05
开发语言·c++·算法
重生之后端学习1 小时前
74. 搜索二维矩阵
开发语言·数据结构·算法·职场和发展·深度优先
@atweiwei1 小时前
rust所有权机制详解
开发语言·数据结构·后端·rust·内存·所有权
JYeontu1 小时前
程序员都该掌握的“质因数分解”
前端·javascript·算法
with-the-flow1 小时前
从数学底层的底层原理来讲 random 的函数是怎么实现的
c语言·python·算法
tyb3333331 小时前
leetcode:吃苹果和队列
算法·leetcode·职场和发展