백준 18352 JS 풀이

hun2__2·2023년 7월 28일
0

코딩테스트

목록 보기
20/48

구하는 값

시작 노드부터 특정dep를 가지고 있는 노드수

핵심 아이디어

특정 dep를 구하는 것이기 때문에 bfs로 풀이가능

que에 dep를 같이 넣는 방법과, visited에 dep를 기록하는 방법 두가지 풀이가 생각남

아래는 후자풀이

코드

const input = require('fs').readFileSync('dev/stdin').toString().trim().split('\n')

class Queue {
    constructor() {
        this.q = [];
        this.h = 0;
        this.t = 0;
    }
    enque(v) {
        this.q[this.t++] = v;
    }
    deque() {
        const v = this.q[this.h];
        delete this.q[this.h++];
        return v;
    }
    size() {
        return this.t - this.h;
    }
}

const [n, m, k, x] = input[0].split(" ").map(Number);

const graph = Array.from({ length: n + 1 }, () => []);
const visited = new Array(n + 1).fill(-1);

for (let i = 1; i <= m; i++) {
    const [a, b] = input[i].split(" ").map(Number);
    graph[a].push(b);
}

// console.log(graph);

const ans = [];
function bfs(str) {
    const queue = new Queue();
    queue.enque(str);
    visited[str] = 0;

    while (queue.size()) {
        const cur = queue.deque();

        if (visited[cur] === k) ans.push(cur);

        for (const next of graph[cur]) {
            if (visited[next] === -1) {
                queue.enque(next);
                visited[next] = visited[cur] + 1;
            }
        }
    }
}

bfs(x);
ans.sort((a, b) => a - b);
console.log(ans.length ? ans.join("\n") : -1);

/** visited의 값을 0으로 해놓고 하면 안되는이유
 *  반례 : 자기자신한데 가는 노드가 생길 경우 0이 아닌 1이 저장됨
 */
profile
과정을 적는 곳

0개의 댓글