LeetCode 695. Max Area of Island

LeetCode 695. Max Area of Island

Description:

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):

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#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):

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
#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;
}

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

------本文结束感谢阅读------