프로그래머스 - 네트워크

Lellow_Mellow·2023년 5월 30일
1
post-thumbnail

✨ Lv. 3 - 네트워크

문제 링크 : https://school.programmers.co.kr/learn/courses/30/lessons/43162

문제 설명

네트워크란 컴퓨터 상호 간에 정보를 교환할 수 있도록 연결된 형태를 의미합니다. 예를 들어, 컴퓨터 A와 컴퓨터 B가 직접적으로 연결되어있고, 컴퓨터 B와 컴퓨터 C가 직접적으로 연결되어 있을 때 컴퓨터 A와 컴퓨터 C도 간접적으로 연결되어 정보를 교환할 수 있습니다. 따라서 컴퓨터 A, B, C는 모두 같은 네트워크 상에 있다고 할 수 있습니다.

컴퓨터의 개수 n, 연결에 대한 정보가 담긴 2차원 배열 computers가 매개변수로 주어질 때, 네트워크의 개수를 return 하도록 solution 함수를 작성하시오.


제한사항

  • 컴퓨터의 개수 n은 1 이상 200 이하인 자연수입니다.
  • 각 컴퓨터는 0부터 n-1인 정수로 표현합니다.
  • i번 컴퓨터와 j번 컴퓨터가 연결되어 있으면 computers[i][j]를 1로 표현합니다.
  • computer[i][i]는 항상 1입니다.

풀이 코드 + 설명

그래프의 연결 요소의 개수를 구하는 문제입니다. 특정 노드의 방문 여부를 저장할 visited 배열과, 연결 요소의 개수를 저장할 result 변수를 선언합니다.

이후, 모든 노드에 대해서 DFS를 반복합니다. 단, DFS는 시작하고자 하는 노드의 visited 값이 false인 경우에만 진행합니다. 각 DFScomputers 배열에 저장된 값을 활용하며, 방문한 노드의 visited 값을 true로 변경합니다.

function solution(n, computers) {
    let visited = new Array(n).fill(false);
    let result = 0;
    
    function DFS(current) {
        visited[current] = true;  
        computers[current].forEach((v, i) => {
            if(v === 1 && !visited[i]) DFS(i);
        })
    }
    
    for(let i = 0; i < n; i++) {
        if(!visited[i]) {
            result++;
            DFS(i);
        }
    }
    
    return result;
}   

profile
잔잔한 물결에서 파도로, 도약을 위한 도전. 함께하는 성장

0개의 댓글