N*N의 섬나라 아일랜드의 지도가 격자판의 정보로 주어집니다. 각 섬은 1로 표시되어 상하좌
우와 대각선으로 연결되어 있으며, 0은 바다입니다. 섬나라 아일랜드에 몇 개의 섬이 있는지
구하는 프로그램을 작성하세요.
입력
7
1 1 0 0 0 1 0
0 1 1 0 1 1 0
0 1 0 0 0 0 0
0 0 0 1 0 1 1
1 1 0 1 1 0 0
1 0 0 0 1 0 0
1 0 1 0 1 0 0
출력
5
1
일 때만 DFS 혹은 BFS 알고리즘으로 1
이 끊기는 지점까지를 섬으로 간주한다.0
으로 바꾼다.[0, 1, 1, 1, 0, -1, -1, -1]
, y 축으로 [1, 1, 0, -1, -1, -1, 0, 1]
가 있다. (시계방향)const solution = (board) => {
let island = 0;
const N = board.length;
const dx = [0, 1, 1, 1, 0, -1, -1, -1];
const dy = [1, 1, 0, -1, -1, -1, 0, 1];
const DFS = (x, y) => {
board[x][y] = 0;
for (let k = 0; k < 8; k++) {
const nx = x + dx[k];
const ny = y + dy[k];
if (nx >= 0 && nx < N && ny >= 0 && ny < N && board[nx][ny] === 1) {
DFS(nx, ny);
}
}
};
for (let i = 0; i < N; i++) {
for (let j = 0; j < N; j++) {
if (board[i][j] === 1) {
island++;
DFS(i, j);
}
}
}
return island;
};
const solution = (board) => {
let island = 0;
const N = board.length;
const dx = [0, 1, 1, 1, 0, -1, -1, -1];
const dy = [1, 1, 0, -1, -1, -1, 0, 1];
for (let i = 0; i < N; i++) {
for (let j = 0; j < N; j++) {
const queue = [];
if (board[i][j] === 1) {
board[i][j] = 0;
island++;
queue.push([i, j]);
while (queue.length) {
const cur = queue.shift();
board[cur[0]][cur[1]] = 0;
for (let k = 0; k < 8; k++) {
const nx = cur[0] + dx[k];
const ny = cur[1] + dy[k];
if (nx >= 0 && nx < N && ny >= 0 && ny < N && board[nx][ny] === 1) {
queue.push([nx, ny]);
}
}
}
}
}
}
return island;
};