๐Ÿ’ฏ CodingTest/BaekJoon

[BaekJoon] 2606๋ฒˆ ๋ฐ”์ด๋Ÿฌ์Šค

S.Honey 2022. 6. 2. 13:56

โ–ถ ๋ฌธ์ œ : https://www.acmicpc.net/problem/2606

 

2606๋ฒˆ: ๋ฐ”์ด๋Ÿฌ์Šค

์ฒซ์งธ ์ค„์—๋Š” ์ปดํ“จํ„ฐ์˜ ์ˆ˜๊ฐ€ ์ฃผ์–ด์ง„๋‹ค. ์ปดํ“จํ„ฐ์˜ ์ˆ˜๋Š” 100 ์ดํ•˜์ด๊ณ  ๊ฐ ์ปดํ“จํ„ฐ์—๋Š” 1๋ฒˆ ๋ถ€ํ„ฐ ์ฐจ๋ก€๋Œ€๋กœ ๋ฒˆํ˜ธ๊ฐ€ ๋งค๊ฒจ์ง„๋‹ค. ๋‘˜์งธ ์ค„์—๋Š” ๋„คํŠธ์›Œํฌ ์ƒ์—์„œ ์ง์ ‘ ์—ฐ๊ฒฐ๋˜์–ด ์žˆ๋Š” ์ปดํ“จํ„ฐ ์Œ์˜ ์ˆ˜๊ฐ€ ์ฃผ์–ด

www.acmicpc.net

 

โ–ถ ์ฝ”๋“œ:

let input = require('fs').readFileSync(`BaekJoon/testcase.txt`).toString().split('\n');

function BFS (graph, start, num){
    const visited = Array(num).fill(false);
    const q = [];
    let count = 0;
    const firstN = graph[0];
    visited[0] = true;
    q.push(...firstN);

    while(q.length !== 0){
        const num = q.shift();    
                    
        if(visited[num]){
            continue;
        }
        visited[num] = true;
        const neighbors = graph[num];
        q.push(...neighbors);
        count += 1;
    }

    return count;
}

let [comsNum, edgeNum, ...edges] = input;
comsNum = Number(comsNum);
edgeNum = Number(edgeNum);

const graph = Array.from(Array(comsNum).fill([]));

for (let i = 0; i < edgeNum; i++){
    let [x, y] = edges[i].split(' ').map(num => Number(num));
    graph[x-1] = [...graph[x-1], y-1];
    graph[y-1] = [...graph[y-1], x-1];
}

const answer = BFS(graph, 0, comsNum);

console.log(answer);

 

โ–ถ ๋ฌธ์ œ ํ’€์ด :

1. ์ปดํ“จํ„ฐ ์ˆ˜์˜ ์ •๋ณด์™€ ๊ฐ„์„ ์˜ ์ •๋ณด๋ฅผ ์ด์šฉํ•ด ์ธ์ ‘ํ–‰๋ ฌ๋กœ ๊ทธ๋ž˜ํ”„๋ฅผ ๊ตฌํ˜„ํ•œ๋’ค BFSํ•จ์ˆ˜์˜ ์ธ์ž๋กœ graph๋ฅผ ๋„˜๊ฒจ์ฃผ๋Š” ๋ฐฉ์‹์„ ์„ ํƒํ•˜์˜€๋‹ค.

2. BFS ํ•จ์ˆ˜๋Š” ๋ฐฐ์—ด์„ Queue(ํ) ์ž๋ฃŒ๊ตฌ์กฐ์™€ ๊ฐ™์ด ์‚ฌ์šฉํ•˜๋ฉฐ ๊ฐ๊ฐ์˜ ๋…ธ๋“œ๊ฐ€ ์—ฐ๊ฒฐ๋˜์–ด์žˆ๋Š” ๊ทธ๋ž˜ํ”„ ์ •๋ณด์™€ ๋ฐฉ๋ฌธํ–ˆ๋Š”์ง€์˜ visited์— ๋Œ€ํ•œ ์ •๋ณด๋ฅผ ์ด์šฉํ•ด ๊ทธ๋ž˜ํ”„๋ฅผ ํƒ์ƒ‰ํ•˜๊ณ , ์ดˆ๊ธฐ ์‹œ์ž‘์ธ 0๋ฒˆ ๋…ธ๋“œ์—์„œ ๋‹ค๋ฅธ ๋…ธ๋“œ๊นŒ์ง€ ์ด ๋ช‡๊ฐœ์˜ ๋…ธ๋“œ๊ฐ€ ์—ฐ๊ฒฐ๋˜์–ด ์žˆ๋Š”์ง€ count์— ์ €์žฅํ•œ๋‹ค.(์ด๋•Œ ์‹œ์ž‘์ ์ธ 0๋ฒˆ ๋…ธ๋“œ์˜ ์ˆ˜๋Š” ์ œ์™ธ) 

3. BFS ํ•จ์ˆ˜์˜ ๊ฒฐ๊ณผ๋ฅผ ์ถœ๋ ฅํ•ด์ฃผ๋ฉด ๋„์•~