-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path0463. Island Perimeter.cpp
More file actions
43 lines (37 loc) · 912 Bytes
/
0463. Island Perimeter.cpp
File metadata and controls
43 lines (37 loc) · 912 Bytes
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
// Task : https://leetcode.com/problems/island-perimeter/description/?envType=daily-question&envId=2024-04-18
#include <iostream>
#include <vector>
int islandPerimeter(std::vector<std::vector<int>> grid) {
int P = 0;
for (size_t i = 0; i < grid.size(); i++) {
for (size_t j = 0; j < grid[0].size(); j++) {
if (grid[i][j] == 1) {
P += 4;
if (i > 0 && grid[i - 1][j] == 1) {
P -= 2;
}
if (j > 0 && grid[i][j - 1] == 1) {
P -= 2;
}
}
}
}
return P;
}
int main() {
// Example 1:
std::vector<std::vector<int>> vec1 = {
{0, 1, 0, 0},
{1, 1, 1, 0},
{0, 1, 0, 0},
{1, 1, 0, 0}
};
std::cout << islandPerimeter(vec1) << '\n';
// Example 2:
std::vector<std::vector<int>> vec2 = { { 1 } };
std::cout << islandPerimeter(vec2) << '\n';
// Example 3:
std::vector<std::vector<int>> vec3 = { { 1, 0 } };
std::cout << islandPerimeter(vec1) << '\n';
return 0;
}