베어_
TechBear
베어_
전체 방문자
오늘
어제
  • 분류 전체보기 (336)
    • Spring (33)
      • 개념 (13)
      • Security (5)
      • 실습 (1)
      • 토비 스프링 (11)
    • JPA (6)
    • 프로젝트 기록 (24)
    • DB (13)
    • JAVA (18)
    • 알고리즘 (50)
      • 유형정리 (8)
      • Baekjoon (21)
      • LeetCode (18)
    • 디자인패턴 (0)
    • 개발서적 (79)
      • Effective Java (78)
      • 객체지향의 사실과 오해 (1)
    • 독후감 (4)
    • 보안 (2)
    • 운영체제(OS) (53)
      • 공룡책 (53)
    • 컴퓨터 네트워크 (28)
      • 컴퓨터 네트워크 하향식 접근 (23)
    • 자료구조 (1)
    • DevOps (2)
    • 앱 개발 (20)
      • 안드로이드 스튜디오 (20)

블로그 메뉴

    공지사항

    인기 글

    태그

    • 백준
    • java
    • C++
    • 함수형인터페이스
    • 이펙티브자바
    • 코드업
    • 알고리즘
    • jpa
    • leetcode
    • 토비스프링
    • 운영체제
    • 자바
    • BFS
    • dfs
    • Spring
    • 스프링
    • 데이터베이스
    • 자바8
    • 스레드
    • 스프링시큐리티

    최근 댓글

    최근 글

    티스토리

    hELLO · Designed By 정상우.
    베어_

    TechBear

    [백준] 2606 바이러스(JAVA)
    알고리즘/Baekjoon

    [백준] 2606 바이러스(JAVA)

    2022. 3. 22. 00:11

    ✉️문제

    https://www.acmicpc.net/problem/2606

     

    2606번: 바이러스

    첫째 줄에는 컴퓨터의 수가 주어진다. 컴퓨터의 수는 100 이하이고 각 컴퓨터에는 1번 부터 차례대로 번호가 매겨진다. 둘째 줄에는 네트워크 상에서 직접 연결되어 있는 컴퓨터 쌍의 수가 주어

    www.acmicpc.net

     

    📝 접근

    이 문제를 풀기 위해서는 2가지를 알아야 한다.

     

    DFS 또는 BFS

    -> 본인은 DFS를 통해 문제를 풀었다.

    -> DFS의 핵심은 재귀이며, 똑같은 정점을 방문하지 않도록 추가적인 체크배열이 필요하다.

    public static void DFS(int idx) {
        ch[idx] = 1;
        for(int n : graph.get(idx)) {
            if(ch[n] == 0) {
                answer++;
                DFS(n);
            }
        }
    }

     

    인접 행렬

    -> 1번 컴퓨터와 연결된 2번 5번을 인접 행렬로 표현하면 다음과 같다. (연결된 컴퓨터는 방향이 없기 때문에 1 -> 2,  2 -> 1 서로 연결해주어야 한다)

    int[][] graph = new int[5][5];
    graph[1][2] = 1;
    graph[2][1] = 1;
    
    graph[1][5] = 1;
    graph[5][1] = 1;

     

     

    🗝 문제풀이

    import java.util.ArrayList;
    import java.util.Scanner;
    
    public class B2606 {
    
        static ArrayList<ArrayList<Integer>> graph;
        static int[] ch;
        static int answer;
    
        public static void main(String[] args) {
            Scanner sc = new Scanner(System.in);
    
            int n = sc.nextInt(); // 컴퓨터 수
            int m = sc.nextInt(); // 연결 쌍
            ch = new int[n+1];
    
            graph = new ArrayList<>();
            for(int i = 0; i <= n; i++) {
                graph.add(new ArrayList<>());
            }
    
            for(int i = 0; i < m; i++) {
                int a = sc.nextInt();
                int b = sc.nextInt();
                graph.get(a).add(b);
                graph.get(b).add(a);
            }
    
            DFS(1);
            System.out.println(answer);
        }
    
        public static void DFS(int idx) {
            ch[idx] = 1;
            for(int n : graph.get(idx)) {
                if(ch[n] == 0) {
                    answer++;
                    DFS(n);
                }
            }
        }
    }
      '알고리즘/Baekjoon' 카테고리의 다른 글
      • [백준] 7569 토마토 (JAVA)
      • [백준] 7576 토마토 (JAVA)
      • [백준] 10830 행렬 제곱 (JAVA)
      • [백준] 1629 곱셈 (JAVA)
      베어_
      베어_
      Today I learned | 문제를 해결하는 개발자

      티스토리툴바