LeetCode 695. Max Area of Island

LeetCode 695. Max Area of Island

问题描述:

Given a non-empty 2D array grid of 0’s and 1’s, an island is a group of 1’s (representing land) connected 4-directionally (horizontal or vertical.) You may assume all four edges of the grid are surrounded by water.

Find the maximum area of an island in the given 2D array. (If there is no island, the maximum area is 0.)

Difficulty: Easy

Example 1:

input:
[[0,0,1,0,0,0,0,1,0,0,0,0,0],
[0,0,0,0,0,0,0,1,1,1,0,0,0],
[0,1,1,0,1,0,0,0,0,0,0,0,0],
[0,1,0,0,1,1,0,0,1,0,1,0,0],
[0,1,0,0,1,1,0,0,1,1,1,0,0],
[0,0,0,0,0,0,0,0,0,0,1,0,0],
[0,0,0,0,0,0,0,1,1,1,0,0,0],
[0,0,0,0,0,0,0,1,1,0,0,0,0]]

Given the above grid, return 6. Note the answer is not 11, because the island must be connected 4-directionally.

Example 2:

[[0,0,0,0,0,0,0,0]]

Given the above grid, return 0.


解法一(DFS):

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
class Solution {
public:
    int maxAreaOfIsland(vector<vector<int>>& grid) {
        int m = grid.size(), n = grid[0].size();// m:grid的行数; n:grid的列数
        int ans = 0;
        for (int i = 0; i < m; i++) {
            for (int j = 0; j < n; j++) {
                // 遍历每一个位置,==1,深度优先搜索
                if (grid[i][j] == 1) ans = max(ans, dfs(grid, m, n, i, j));
            }
        }
        return ans;
    }
private:
    int dfs(vector<vector<int>>& grid, int m, int n, int row, int col) {
        int area = 1;
        grid[row][col] = 2;// 标记已经遍历过的满足条件的值
        vector<int> dir({-1, 0, 1, 0, -1});// 搜索的方向:上下左右
        for (int i = 0; i < 4; i++) {
            int r = row + dir[i], c = col + dir[i + 1];
            // 边界判断以及陆地判断
            // 若为真,继续深搜
            if (r >= 0 && r < m && c >= 0 && c < n && grid[r][c] == 1){
                area += dfs(grid, m, n, r, c);
            }
        }
        return area;
    }
};
int main() {
    Solution s;
    vector<vector<int>> grid = 
    {{0,0,1,0,0,0,0,1,0,0,0,0,0},
    {0,0,0,0,0,0,0,1,1,1,0,0,0},
    {0,1,1,0,1,0,0,0,0,0,0,0,0},
    {0,1,0,0,1,1,0,0,1,0,1,0,0},
    {0,1,0,0,1,1,0,0,1,1,1,0,0},
    {0,0,0,0,0,0,0,0,0,0,1,0,0},
    {0,0,0,0,0,0,0,1,1,1,0,0,0},
    {0,0,0,0,0,0,0,1,1,0,0,0,0}};

    for (int i = 0; i < grid.size(); i++) {
        for (int j = 0; j < grid[0].size(); j++) {
            cout << grid[i][j] << " ";
        }
        cout << endl;
    }
    cout << s.maxAreaOfIsland(grid) << endl;
    return 0;
}

解法二(BFS):

#include <iostream>
#include <vector>
#include <queue>
#include <algorithm>
using namespace std;
class Solution {
public:
    int maxAreaOfIsland(vector<vector<int>>& grid) {
        int m = grid.size(), n = grid[0].size();// m:grid的行数; n:grid的列数
        int ans = 0;
        for (int i = 0; i < m; i++) {
            for (int j = 0; j < n; j++) {
                // 遍历每一个位置,==1,宽度优先搜索
                if (grid[i][j] == 1) ans = max(ans, bfs(grid, m, n, i, j));
            }
        }
        return ans;
    }
private:
    int bfs(vector<vector<int>>& grid, int m, int n, int row, int col) {
        int area = 1;

        queue<pair<int, int>> q;
        q.push({row, col});// 将已经遍历过的满足条件的结点放进队列

        grid[row][col] = 2;// 标记已经遍历过的满足条件的值
        vector<int> dir({-1, 0, 1, 0, -1});// 搜索的方向:上下左右

        while (!q.empty()) {
            int z = q.front().first, x = q.front().second;// 获取结点的行号、列号
            q.pop();// 删除该结点

            for (int i = 0; i < 4; i++) {
                int r = z + dir[i], c = x + dir[i + 1];
                // 边界判断以及陆地判断
                if (r >= 0 && r < m && c >= 0 && c < n && grid[r][c] == 1){
                    grid[r][c] = 2;// 标记已经遍历过的满足条件的值
                    area++;
                    q.push({r, c});// 将已经遍历过的满足条件的结点放进队列
                }
            }
        }
        return area;
    }
};
int main() {
    Solution s;
    vector<vector<int>> grid = 
    {{0,0,1,0,0,0,0,1,0,0,0,0,0},
    {0,0,0,0,0,0,0,1,1,1,0,0,0},
    {0,1,1,0,1,0,0,0,0,0,0,0,0},
    {0,1,0,0,1,1,0,0,1,0,1,0,0},
    {0,1,0,0,1,1,0,0,1,1,1,0,0},
    {0,0,0,0,0,0,0,0,0,0,1,0,0},
    {0,0,0,0,0,0,0,1,1,1,0,0,0},
    {0,0,0,0,0,0,0,1,1,0,0,0,0}};

    for (int i = 0; i < grid.size(); i++) {
        for (int j = 0; j < grid[0].size(); j++) {
            cout << grid[i][j] << " ";
        }
        cout << endl;
    }
    cout << s.maxAreaOfIsland(grid) << endl;
    return 0;
}

运行结果为:
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值