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

2022. 5. 27. 16:13ยท๐Ÿ’ฏ CodingTest/BaekJoon

โ–ถ ๋ฌธ์ œ : 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๋ฅผ ์ถœ๋ ฅํ•˜๋ฉด ๋„์•!

 

'๐Ÿ’ฏ CodingTest > BaekJoon' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€

[Baekjoon] 1764 ๋“ฃ๋ณด์žก  (0) 2022.05.27
[Baekjoon] 1676 ํŒฉํ† ๋ฆฌ์–ผ 0์˜ ๊ฐœ์ˆ˜  (0) 2022.05.27
[BaekJoon] 1620 ๋‚˜๋Š”์•ผ ํฌ์ผ“๋ชฌ ๋งˆ์Šคํ„ฐ ์ด๋‹ค์†œ  (0) 2022.04.15
[BaekJoon] 1541 ์žƒ์–ด๋ฒ„๋ฆฐ ๊ด„ํ˜ธ  (0) 2022.04.15
[BaekJoon] 1463 1๋กœ ๋งŒ๋“ค๊ธฐ  (0) 2022.04.14
'๐Ÿ’ฏ CodingTest/BaekJoon' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
  • [Baekjoon] 1764 ๋“ฃ๋ณด์žก
  • [Baekjoon] 1676 ํŒฉํ† ๋ฆฌ์–ผ 0์˜ ๊ฐœ์ˆ˜
  • [BaekJoon] 1620 ๋‚˜๋Š”์•ผ ํฌ์ผ“๋ชฌ ๋งˆ์Šคํ„ฐ ์ด๋‹ค์†œ
  • [BaekJoon] 1541 ์žƒ์–ด๋ฒ„๋ฆฐ ๊ด„ํ˜ธ
S.Honey
S.Honey
  • S.Honey
    Algo ์“ฐ์ž
    S.Honey
  • ์ „์ฒด
    ์˜ค๋Š˜
    ์–ด์ œ
    • ๋ถ„๋ฅ˜ ์ „์ฒด๋ณด๊ธฐ (123)
      • ํšŒ๊ณ  (0)
        • ์ทจ์—… ํ›„ ํšŒ๊ณ  (0)
      • ๐Ÿƒ Frontend Road-Map (2)
        • ๐Ÿšฉ Summary (1)
        • ๐Ÿ“š Road-Map Contents (1)
        • ๐ŸŸง HTML (0)
        • ๐ŸŸฆ CSS (0)
        • ๐ŸŸจ Javascript (0)
        • โฌœ React (0)
        • ๐ŸŸช Redux (0)
      • Backend (0)
        • QueryDSL (0)
      • ๐Ÿ’ป Programming Language (54)
        • C# (51)
        • Flutter-Dart (3)
        • Java (0)
      • ๐Ÿ“š Computer Science (4)
        • Algorithms (4)
        • Database (0)
        • Network (0)
        • Operating System(OS) (0)
      • ๐Ÿ’ฏ CodingTest (60)
        • BaekJoon (22)
        • Programmers (34)
        • CodeTree (4)
      • โœ’๏ธ Design Pattern (1)
      • ๐Ÿฑ Etc (2)
        • Jenkins Plugin ์ œ์ž‘๊ธฐ (1)
  • ๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

    • ๋งํฌ

    • ๊ณต์ง€์‚ฌํ•ญ

      • ๐Ÿ“– ๊ณต๋ถ€ ์ฐธ๊ณ  ๊ต์žฌ ๋ฐ ์ž๋ฃŒ
    • ์ธ๊ธฐ ๊ธ€

    • ํƒœ๊ทธ

      DP
      Flutter
      ์ž๋ฃŒ๊ตฌ์กฐ
      sort
      ์ฝ”๋”ฉํ…Œ์ŠคํŠธ
      DART
      ์•Œ๊ณ ๋ฆฌ์ฆ˜
      ์นด์นด์˜ค
      ๋ฌธ์ž์—ด ํŒŒ์‹ฑ
      Java
      BAEKJOON
      ํŒŒ์ด์ฌ
      ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค
      BFS
      Algorithm
      JS
      ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ
      ์ฝ”๋“œํŠธ๋ฆฌ
      ๊ทธ๋ž˜ํ”„ ํƒ์ƒ‰
      ์‚ผ์„ฑsw์—ญํ…Œ
      c#
      JavaScript
      ์Šคํ„ฐ๋””
      ๋ฐฑ์ค€
      ์ด์ง„ํƒ์ƒ‰
      ์‹œ๋ฎฌ๋ ˆ์ด์…˜
      ๋™์  ํ”„๋กœ๊ทธ๋ž˜๋ฐ
      programmers
      ๊ตฌํ˜„
      ์“ฐ์…จ์ž–์•„
    • ์ตœ๊ทผ ๋Œ“๊ธ€

    • ์ตœ๊ทผ ๊ธ€

    • hELLOยท Designed By์ •์ƒ์šฐ.v4.10.1
    S.Honey
    [Baekjoon] 1389๋ฒˆ ์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ 6๋‹จ๊ณ„ ๋ฒ•์น™
    ์ƒ๋‹จ์œผ๋กœ

    ํ‹ฐ์Šคํ† ๋ฆฌํˆด๋ฐ”