๐Ÿ’ฏ CodingTest/BaekJoon

[Baekjoon] 1389๋ฒˆ ์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ 6๋‹จ๊ณ„ ๋ฒ•์น™

S.Honey 2022. 5. 27. 16:13

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

 

1389๋ฒˆ: ์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ 6๋‹จ๊ณ„ ๋ฒ•์น™

์ฒซ์งธ ์ค„์— ์œ ์ €์˜ ์ˆ˜ N (2 ≤ N ≤ 100)๊ณผ ์นœ๊ตฌ ๊ด€๊ณ„์˜ ์ˆ˜ M (1 ≤ M ≤ 5,000)์ด ์ฃผ์–ด์ง„๋‹ค. ๋‘˜์งธ ์ค„๋ถ€ํ„ฐ M๊ฐœ์˜ ์ค„์—๋Š” ์นœ๊ตฌ ๊ด€๊ณ„๊ฐ€ ์ฃผ์–ด์ง„๋‹ค. ์นœ๊ตฌ ๊ด€๊ณ„๋Š” A์™€ B๋กœ ์ด๋ฃจ์–ด์ ธ ์žˆ์œผ๋ฉฐ, A์™€ B๊ฐ€ ์นœ๊ตฌ๋ผ๋Š” ๋œป

www.acmicpc.net

 

โ–ถ ์ฝ”๋“œ :

let input = require('fs').readFileSync(`Computer Science/Alogrithms/๋ฐฑ์ค€JS/testCase.txt`).toString().split('\n');

const [n, m] = input[0].split(' ').map(num => parseInt(num))

let kevin = Infinity;
let answer = 0;
let graph = Array.from(new Array(n+1).fill(new Array()));

for (let i = 1; i<= m; i++){
    const [node1,node2] = input[i].split(' ').map(num => parseInt(num));
    
    graph[node1] = [...graph[node1], node2];
    graph[node2] = [...graph[node2], node1];
}

for (let i = 1; i<= n; i++){
    let temp = BFS(graph, i, n);
    
    if(kevin > temp){
        kevin = temp;
        answer = i;
    }
}

console.log(answer);



function BFS(graph,startNum, n){   
    let kevinNum = 0;

    let q = [[startNum,0]];
    let visited = Array(n+1).fill(false);
    
    while (q.length != 0){
        let [v, count] = q.shift();

        if(visited[v] === false){
            graph[v].map(num => {q.push([num, count+1])});
            visited[v] = true;
            kevinNum += count;
        }
    }
    
    return kevinNum;
}

 

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

1. ๊ทธ๋ž˜ํ”„ ํƒ์ƒ‰์„ ์ด์šฉํ•ด์•ผ ํ•œ๋‹ค๋Š” ์ ์„ ์—ผ๋‘ํ–ˆ์œผ๋ฉฐ, ๊ฐ๊ฐ์˜ ๋…ธ๋“œ๋Š” ์–‘๋ฐฉํ–ฅ ์—ฐ๊ฒฐ๋˜์–ด์žˆ๋‹ค.

2. ์ดˆ๊ธฐ ์–‘๋ฐฉํ–ฅ ์—ฐ๊ฒฐ์„ ์œ„ํ•ด for๋ฌธ์œผ๋กœ ์ž…๋ ฅ์„ ์ฒ˜๋ฆฌํ•˜์—ฌ ๊ทธ๋ž˜ํ”„๋ฅผ ์ƒ์„ฑํ•˜์˜€๋‹ค.

3. function BFS๋ฅผ ์„ ์–ธํ•˜์˜€๋‹ค.

  3-1. ์ธ์ž๋กœ๋Š” graph, startNum, n(์‚ฌ๋žŒ์˜ ์ˆ˜) ๋ฅผ ์ž…๋ ฅ ๋ฐ›๋Š”๋‹ค.

  3-2. BFS๋Š” startNum์—์„œ๋ถ€ํ„ฐ ๊ฐ๊ฐ์˜ ์‚ฌ๋žŒ๋“ค์„ ๋ชจ๋‘ ๋งŒ๋‚˜๊ธฐ๊นŒ์ง€ ๋ฐ˜๋ณตํ•œ๋‹ค.

  3-3. ๋…ธ๋“œ๋ฅผ ํƒ์ƒ‰ํ•˜๋ฉฐ queue์— ํ•ด๋‹น ๋…ธ๋“œ์˜ ๋ฒˆํ˜ธ์™€ ํ•ด๋‹น ๋…ธ๋“œ๊นŒ์ง€์˜ count๋ฅผ ์ €์žฅํ•˜๋ฉฐ, ๊ฐ๊ฐ์˜ ๋…ธ๋“œ๋ฅผ ์ฒ˜์Œ ๋ฐฉ๋ฌธํ• ๋•Œ๋งˆ๋‹ค kevinNum์— ๋”ํ•ด์ค€๋‹ค. => BFS๋Š” ๋ฃจํŠธ ๋…ธ๋“œ๋กœ๋ถ€ํ„ฐ ํ•˜์œ„ ๋…ธ๋“œ๊นŒ์ง€์˜ ์ตœ๋‹จ๊ฑฐ๋ฆฌ๋ฅผ ๊ตฌํ•  ์ˆ˜ ์žˆ๊ธฐ ๋•Œ๋ฌธ์— count๋ฅผ ๋น„๊ตํ•  ๋กœ์ง์€ ๋ณ„๋„๋กœ ํ•„์š”๊ฐ€ ์—†๋‹ค.

4. BFS ํ•จ์ˆ˜๋ฅผ ์ด์šฉํ•ด ์ฃผ์–ด์ง„ ์‚ฌ๋žŒ์˜ ์ˆ˜ ๋งŒํผ(์ด๋•Œ ์‚ฌ๋žŒ์˜ ๋ฒˆํ˜ธ๋Š” 1๋ถ€ํ„ฐ ์‹œ์ž‘) ๋ฐ˜๋ณตํ•˜๋ฉฐ ๊ฐ€์žฅ ์ž‘์€ ๊ฐ’์˜ ์ผ€๋นˆ ๋ฒ ์ด์ปจ ์ˆ˜๋ฅผ ๊ฐ€์ง„ ์‚ฌ๋žŒ์˜ ๋ฒˆํ˜ธ๋ฅผ answer์— ์ €์žฅํ•œ๋‹ค.

5. ์ดํ›„ answer๋ฅผ ์ถœ๋ ฅํ•˜๋ฉด ๋„์•!