문제
data:image/s3,"s3://crabby-images/0503c/0503c2ecfddcac43125cee21cf8999508d524fa0" alt=""
제한 사항
data:image/s3,"s3://crabby-images/93358/93358f669e88796a85d065a7b0e3a3465eb576cb" alt=""
입출력 예
data:image/s3,"s3://crabby-images/f66dd/f66dd74c3de31ecba85d824da5aab812ce9289aa" alt=""
풀이
let input = require('fs').readFileSync('/dev/stdin').toString().trim().split('\n');
const solution = (input) => {
const [n, m] = input.shift().split(" ").map(Number);
const table = input.map((e) => e.split("").map(Number));
const visited = Array.from(Array(m), () => Array(n).fill(0));
const dx = [-1, 0, 1, 0];
const dy = [0, 1, 0, -1];
const queue = [];
visited[0][0] = 1;
queue.push([0, 0, 0]);
while (queue.length) {
const [x, y, cnt] = queue.shift();
if (x === m - 1 && y === n - 1) {
return cnt;
}
for (let i = 0; i < 4; i++) {
let nx = x + dx[i];
let ny = y + dy[i];
if (nx < 0 || ny < 0 || nx >= m || ny >= n) continue;
if (table[nx][ny] === 0 && !visited[nx][ny]) {
visited[nx][ny] = 1;
queue.unshift([nx, ny, cnt]);
}
if (table[nx][ny] === 1 && !visited[nx][ny]) {
visited[nx][ny] = 1;
queue.push([nx, ny, cnt + 1]);
}
}
}
};
console.log(solution(input));
- 벽을 안 부시는걸 먼저 처리해줘야 함으로 unshift를 사용해줬다.