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

2022. 6. 2. 13:56ยท๐Ÿ’ฏ CodingTest/BaekJoon

โ–ถ ๋ฌธ์ œ : 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 ํ•จ์ˆ˜์˜ ๊ฒฐ๊ณผ๋ฅผ ์ถœ๋ ฅํ•ด์ฃผ๋ฉด ๋„์•~

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

[BaekJoon] 17219๋ฒˆ ๋น„๋ฐ€๋ฒˆํ˜ธ ์ฐพ๊ธฐ  (0) 2022.06.03
[BaekJoon] 11724๋ฒˆ ์—ฐ๊ฒฐ ์š”์†Œ์˜ ๊ฐœ์ˆ˜  (0) 2022.06.03
[BaekJoon] 2579๋ฒˆ ๊ณ„๋‹จ ์˜ค๋ฅด๊ธฐ  (0) 2022.06.02
[Baekjoon] 1764 ๋“ฃ๋ณด์žก  (0) 2022.05.27
[Baekjoon] 1676 ํŒฉํ† ๋ฆฌ์–ผ 0์˜ ๊ฐœ์ˆ˜  (0) 2022.05.27
'๐Ÿ’ฏ CodingTest/BaekJoon' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
  • [BaekJoon] 17219๋ฒˆ ๋น„๋ฐ€๋ฒˆํ˜ธ ์ฐพ๊ธฐ
  • [BaekJoon] 11724๋ฒˆ ์—ฐ๊ฒฐ ์š”์†Œ์˜ ๊ฐœ์ˆ˜
  • [BaekJoon] 2579๋ฒˆ ๊ณ„๋‹จ ์˜ค๋ฅด๊ธฐ
  • [Baekjoon] 1764 ๋“ฃ๋ณด์žก
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)
  • ๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

    • ๋งํฌ

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

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

    • ํƒœ๊ทธ

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

    • ์ตœ๊ทผ ๊ธ€

    • hELLOยท Designed By์ •์ƒ์šฐ.v4.10.1
    S.Honey
    [BaekJoon] 2606๋ฒˆ ๋ฐ”์ด๋Ÿฌ์Šค
    ์ƒ๋‹จ์œผ๋กœ

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