티스토리 뷰
Question
Given an m x n 2D binary grid [grid] which represents a map of '1's (land) and '0's (water), return the number of islands.
An island is surrounded by water and is formed by connecting adjacent lands horizontally or vertically. You may assume all four edges of the grid are all surrounded by water.
m x n 인 2차원 grid가 주어진다. grid의 1은 땅, 0은 물을 의미할 때 island의 개수를 세라. island는 물로 상하좌우가 둘러싸인 땅을 의미한다.
제약사항
- m == grid.length
- n == grid[i].length
- 1 <= m, n <= 300
- grid [i][j]is '0' or '1'.
Solution
문제를 풀 때 고려한 사항
- 주어진 맵의 크기가 1x1일 때 알고리즘이 정상 동작해야 한다.
Solution
가장 쉽게 생각할 수 있는 방법은 BFS이다.
class Solution {
public:
int dx[4] = {1, -1, 0, 0};
int dy[4] = {0, 0, 1, -1};
int numIslands(vector<vector<char>>& grid) {
int m = grid.size();
int n = grid[0].size();
queue<pair<int,int>> land;
vector<vector<int>> visit(m, vector<int> (n));
int land_count = 0;
for(int i=0; i<m; i++){
for(int j=0; j<n; j++){
if(grid[i][j] == '1' && visit[i][j] == 0){
land.push({i,j});
land_count++;
while(!land.empty()){
pair<int,int> l = land.front();
land.pop();
visit[l.first][l.second] = land_count;
for(int k=0; k<4;k++){
int next_x = l.first + dx[k];
int next_y = l.second + dy[k];
if(next_x <0 || next_y<0 || next_x>=m || next_y>=n) continue;
if(grid[next_x][next_y] != '1' || visit[next_x][next_y]) continue;
visit[next_x][next_y] = land_count;
land.push({next_x, next_y});
}
}
}
}
}
return land_count;
}
};
- Time complexity : O(nm)
- Space Complexity : O(nm)
출처 : https://leetcode.com/explore/interview/card/top-interview-questions-medium/108/trees-and-graphs/792/
'IT > Problem Solving' 카테고리의 다른 글
[C++] Interview Question : Pots of gold game (0) | 2022.08.25 |
---|---|
[C++] Interview Question : find smallest range (0) | 2022.08.24 |
[C++] LeetCode : Kth Smallest Element in a BST (0) | 2022.08.20 |
[C++] LeetCode : Populating Next Right Pointers in Each Node (0) | 2022.08.20 |
[C++] LeetCode : Construct Binary Tree from Preorder and Inorder Traversal (0) | 2022.08.20 |
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- rust
- 트리
- 기술면접
- DP
- C++
- 내돈내산
- 코딩인터뷰
- 러스트 입문
- coding interview
- ProblemSolving
- Interview
- algorithm
- 반드시 알아야 할 자료구조
- Medium
- Tree
- 인터뷰
- 속초 맛집
- PS
- Problem Solving
- 속초
- 러스트 배우기
- 알고리즘
- 자료구조
- interview question
- 러스트
- 러스트 기초
- 솔직후기
- LeetCode
- 리트코드
- 맛집
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함