반응형
12-23 19:41
Today
Total
«   2024/12   »
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30 31
관리 메뉴

개발하는 고라니

[백준] 18405번 : 경쟁적 전염 본문

Programming/백준

[백준] 18405번 : 경쟁적 전염

조용한고라니 2021. 5. 26. 01:03
반응형
 

18405번: 경쟁적 전염

첫째 줄에 자연수 N, K가 공백을 기준으로 구분되어 주어진다. (1 ≤ N ≤ 200, 1 ≤ K ≤ 1,000) 둘째 줄부터 N개의 줄에 걸쳐서 시험관의 정보가 주어진다. 각 행은 N개의 원소로 구성되며, 해당 위치

www.acmicpc.net


[BFS + 우선순위 큐]

1초마다 낮은 번호의 바이러스부터 상하좌우 인접한 칸(단, 0인 곳)으로 한 칸씩 전염시킬 수 있으므로 우선순위 큐를 사용해 낮은 번호의 바이러스부터 퍼지게 한다.

 

그러려면 입력을 받을 때 모든 바이러스를 우선순위 큐에 넣는다.

 

그리고 s번의 루프를 수행하고, 각 루프마다 BFS를 실행하는데 일반적인 BFS는 다음 탐색할 정점을 동일한 큐에 저장하는데 반해, 이 문제에서는 다른 큐(tmpQ라고 지정)에 저장하도록 한다. 이는 1초씩 나누어 탐색을 진행해야 하므로 이처럼 나누어 놓았다.

 

현재 정점의 바이러스가 n번일 때 주변을 탐색을 하기위한 조건은

1) 범위를 넘지 않고

2) 숫자가 0인 곳

을 n으로 수정한다.

# Code </>

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.PriorityQueue;
import java.util.Queue;
import java.util.StringTokenizer;

public class Main {

    static class Point{
        int y, x, v;

        public Point(int y, int x, int v) {
            this.y = y;
            this.x = x;
            this.v = v;
        }
    }

    static int n, k;
    static int[] Y = {-1, 1, 0, 0}, X = {0, 0, -1, 1};
    static int[][] map = new int[201][201];
    static Queue<Point> Q = new PriorityQueue<>((a, b) -> a.v- b.v);

    static void BFS(){
        Queue<Point> tmpQ = new PriorityQueue<>((a, b) -> a.v - b.v);

        while(!Q.isEmpty()) {
            Point p = Q.poll();
            int y = p.y;
            int x = p.x;
            int v = p.v;

            for (int a = 0; a < 4; a++) {
                int ny = y + Y[a];
                int nx = x + X[a];

                if (ny < 1 || nx < 1 || ny > n || nx > n || map[ny][nx] != 0) continue;

                map[ny][nx] = v;
                tmpQ.add(new Point(ny, nx, v));
            }
        }
        Q = tmpQ;
    }

    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        StringTokenizer st = new StringTokenizer(br.readLine());

        n = Integer.parseInt(st.nextToken());
        k = Integer.parseInt(st.nextToken());

        for(int i=1; i<=n; i++){
            st = new StringTokenizer(br.readLine());

            for(int j=1; j<=n; j++){
                map[i][j] = Integer.parseInt(st.nextToken());

                if(map[i][j] != 0)
                    Q.add(new Point(i, j, map[i][j]));
            }
        }
        st = new StringTokenizer(br.readLine());
        int s = Integer.parseInt(st.nextToken());
        int endY = Integer.parseInt(st.nextToken());
        int endX = Integer.parseInt(st.nextToken());

        int time = 0;
        while(time++ != s)
            BFS();

        System.out.println(map[endY][endX]);
    }
}
반응형

'Programming > 백준' 카테고리의 다른 글

[백준] 12763번 : 지각하면 안 돼  (0) 2021.05.30
[백준] 4803번 : 트리  (0) 2021.05.26
[백준] 3709번 : 레이저빔은 어디로  (0) 2021.05.13
[백준] 5430번 : AC  (0) 2021.05.12
[백준] 5884번 : 감시 카메라  (0) 2021.05.11
Comments