섬나라 아일랜드 : DFS, BFS
48087 단어 BFSDFSjavascript 문제풀이BFS
DFS 풀이
내풀이
function solution(board) {
let answer = 0;
const d = [
[1, 0],
[1, -1],
[0, -1],
[-1, -1],
[-1, 0],
[-1, 1],
[0, 1],
[1, 1]
];
const n = board.length;
function DFS(x, y) {
for (let [dx, dy] of d) {
nx = x + dx;
ny = y + dy;
if (0 <= nx && nx < n && 0 <= ny && ny < n && board[nx][ny] === 1) {
board[nx][ny] = 0;
DFS(nx, ny);
}
}
}
for (let i = 0; i < n; i++) {
for (let j = 0; j < n; j++) {
if (board[i][j] === 1) {
board[i][j] = 0;
DFS(i, j);
answer++;
}
}
}
console.log(board);
return an
Solution 풀이
function solution(board) {
let answer = 0;
let n = board.length;
let dx = [-1, -1, 0, 1, 1, 1, 0, -1];
let dy = [0, 1, 1, 1, 0, -1, -1, -1];
function DFS(x, y) {
board[x][y] = 0;
for (let k = 0; k < 8; k++) {
let nx = x + dx[k];
let 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) {
board[i][j] = 0;
answer++;
DFS(i, j);
}
}
}
return answer;
}
let arr = [
[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]
];
console.log(solution(arr));
Comment
거의 비슷하게 푼 것 같다. let [dx, dy]
로 놓고 반복문을 돌리는 방법이 훨씬 직관적인 방식 같다.
BFS 풀이
내 풀이
function solution(board) {
let answer = 0;
const n = board.length;
const d = [
[1, 0],
[1, -1],
[0, -1],
[-1, -1],
[-1, 0],
[-1, 1],
[0, 1],
[1, 1]
];
function BFS(x, y) {
const queue = [];
queue.push([x, y]);
while (queue.length) {
const len = queue.length;
for (let i = 0; i < len; i++) {
const t = queue.shift();
for (let [dx, dy] of d) {
const nx = t[0] + dx;
const ny = t[1] + dy;
if (0 <= nx && nx < n && 0 <= ny && ny < n && board[nx][ny] === 1) {
board[nx][ny] = 0;
queue.push([nx, ny]);
}
}
}
console.log(queue);
}
}
for (let i = 0; i < n; i++) {
for (let j = 0; j < n; j++) {
if (board[i][j] === 1) {
board[i][j] = 0;
BFS(i, j);
answer++;
}
}
}
return answer;
}
let arr = [
[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]
];
console.log(solution(arr));
Solution 풀이
function solution(board) {
let answer = 0;
let n = board.length;
let dx = [-1, -1, 0, 1, 1, 1, 0, -1];
let dy = [0, 1, 1, 1, 0, -1, -1, -1];
let queue = [];
for (let i = 0; i < n; i++) {
for (let j = 0; j < n; j++) {
if (board[i][j] === 1) {
board[i][j] = 0;
queue.push([i, j]);
answer++;
while (queue.length) {
let x = queue.shift();
for (let k = 0; k < 8; k++) {
let nx = x[0] + dx[k];
let ny = x[1] + dy[k];
if (nx >= 0 && nx < n && ny >= 0 && ny < n && board[nx][ny] === 1) {
board[nx][ny] = 0;
queue.push([nx, ny]);
}
}
}
}
}
}
return answer;
}
let arr = [
[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]
];
console.log(solution(arr));
Comment
거의 똑같은데, BFS 함수를 따로 정의해서 푼 내 풀이가 훨씬 가독성이 좋은 것 같다.
Author And Source
이 문제에 관하여(섬나라 아일랜드 : DFS, BFS), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다
https://velog.io/@frenchkebab/섬나라-아일랜드-DFS-BFS
저자 귀속: 원작자 정보가 원작자 URL에 포함되어 있으며 저작권은 원작자 소유입니다.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)
function solution(board) {
let answer = 0;
const d = [
[1, 0],
[1, -1],
[0, -1],
[-1, -1],
[-1, 0],
[-1, 1],
[0, 1],
[1, 1]
];
const n = board.length;
function DFS(x, y) {
for (let [dx, dy] of d) {
nx = x + dx;
ny = y + dy;
if (0 <= nx && nx < n && 0 <= ny && ny < n && board[nx][ny] === 1) {
board[nx][ny] = 0;
DFS(nx, ny);
}
}
}
for (let i = 0; i < n; i++) {
for (let j = 0; j < n; j++) {
if (board[i][j] === 1) {
board[i][j] = 0;
DFS(i, j);
answer++;
}
}
}
console.log(board);
return an
function solution(board) {
let answer = 0;
let n = board.length;
let dx = [-1, -1, 0, 1, 1, 1, 0, -1];
let dy = [0, 1, 1, 1, 0, -1, -1, -1];
function DFS(x, y) {
board[x][y] = 0;
for (let k = 0; k < 8; k++) {
let nx = x + dx[k];
let 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) {
board[i][j] = 0;
answer++;
DFS(i, j);
}
}
}
return answer;
}
let arr = [
[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]
];
console.log(solution(arr));
거의 비슷하게 푼 것 같다. let [dx, dy]
로 놓고 반복문을 돌리는 방법이 훨씬 직관적인 방식 같다.
내 풀이
function solution(board) {
let answer = 0;
const n = board.length;
const d = [
[1, 0],
[1, -1],
[0, -1],
[-1, -1],
[-1, 0],
[-1, 1],
[0, 1],
[1, 1]
];
function BFS(x, y) {
const queue = [];
queue.push([x, y]);
while (queue.length) {
const len = queue.length;
for (let i = 0; i < len; i++) {
const t = queue.shift();
for (let [dx, dy] of d) {
const nx = t[0] + dx;
const ny = t[1] + dy;
if (0 <= nx && nx < n && 0 <= ny && ny < n && board[nx][ny] === 1) {
board[nx][ny] = 0;
queue.push([nx, ny]);
}
}
}
console.log(queue);
}
}
for (let i = 0; i < n; i++) {
for (let j = 0; j < n; j++) {
if (board[i][j] === 1) {
board[i][j] = 0;
BFS(i, j);
answer++;
}
}
}
return answer;
}
let arr = [
[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]
];
console.log(solution(arr));
Solution 풀이
function solution(board) {
let answer = 0;
let n = board.length;
let dx = [-1, -1, 0, 1, 1, 1, 0, -1];
let dy = [0, 1, 1, 1, 0, -1, -1, -1];
let queue = [];
for (let i = 0; i < n; i++) {
for (let j = 0; j < n; j++) {
if (board[i][j] === 1) {
board[i][j] = 0;
queue.push([i, j]);
answer++;
while (queue.length) {
let x = queue.shift();
for (let k = 0; k < 8; k++) {
let nx = x[0] + dx[k];
let ny = x[1] + dy[k];
if (nx >= 0 && nx < n && ny >= 0 && ny < n && board[nx][ny] === 1) {
board[nx][ny] = 0;
queue.push([nx, ny]);
}
}
}
}
}
}
return answer;
}
let arr = [
[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]
];
console.log(solution(arr));
Comment
거의 똑같은데, BFS 함수를 따로 정의해서 푼 내 풀이가 훨씬 가독성이 좋은 것 같다.
Author And Source
이 문제에 관하여(섬나라 아일랜드 : DFS, BFS), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://velog.io/@frenchkebab/섬나라-아일랜드-DFS-BFS저자 귀속: 원작자 정보가 원작자 URL에 포함되어 있으며 저작권은 원작자 소유입니다.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)