문제
data:image/s3,"s3://crabby-images/909a6/909a67d5d31f495e2568585517e0e9b85a38f276" alt=""
제한 사항
data:image/s3,"s3://crabby-images/ce4c7/ce4c70d0b95f7f926de12ebf8b416d6dd73ddf89" alt=""
입출력 예
data:image/s3,"s3://crabby-images/ea1e9/ea1e97f0efdf680bc68b9af7369f3861f33f24d8" alt=""
풀이
let input = require('fs').readFileSync('/dev/stdin').toString().trim();
const solution = (input) => {
let arr = input.split(" ");
const start = +arr.shift();
const end = +arr.shift();
const visited = new Array(100100).fill(0);
const queue = [];
visited[start] = 1;
queue.push([start, 0]);
while (queue.length) {
const [cur, time] = queue.shift();
if (cur == end) return time;
for (let next of [cur - 1, cur + 1, cur * 2]) {
if (!visited[next] && next >= 0 && next <= 100000) {
visited[next] = 1;
if (next === cur * 2) {
queue.unshift([next, time]);
}
queue.push([next, time + 1]);
}
}
}
};
console.log(solution(input));
- *2하는 경우가 시간이 추가되지 않는 것으로 바뀌었다.
- 시간이 늘어나지 않은 것을 먼저 처리해줘야 함으로 unshift를 이용해 큐의 가장 앞에 넣어줬다.