반응형
01-28 23:14
Today
Total
«   2025/01   »
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
관리 메뉴

개발하는 고라니

[백준] 3055번 : 탈출 본문

Programming/백준

[백준] 3055번 : 탈출

조용한고라니 2021. 2. 8. 19:00
반응형
 

3055번: 탈출

사악한 암흑의 군주 이민혁은 드디어 마법 구슬을 손에 넣었고, 그 능력을 실험해보기 위해 근처의 티떱숲에 홍수를 일으키려고 한다. 이 숲에는 고슴도치가 한 마리 살고 있다. 고슴도치는 제

www.acmicpc.net

[2개의 Queue를 이용한 BFS]

이와 비슷한 문제지만 좀더 어려운 문제가 '백조의 호수'라고 생각된다. 이 문제를 풀었다면 아래 문제도 풀어보길 추천하는 바다.

 

[백준] 3197번 : 백조의 호수

3197번: 백조의 호수 입력의 첫째 줄에는 R과 C가 주어진다. 단, 1 ≤ R, C ≤ 1500. 다음 R개의 줄에는 각각 길이 C의 문자열이 하나씩 주어진다. '.'은 물 공간, 'X'는 빙판 공간, 'L'은 백조가 있는 공

dev-gorany.tistory.com

고슴도치의 위치를 넣을 큐 Q와 물의 위치를 넣을 큐 waterQ를 준비한다.

 

입력을 받을 때 '*'이라면 waterQ에 넣고, 'S'라면 Q에 넣고 그 때의 위치 (i, j)를 방문한다. 'S'는 단 하나만 존재한다. 문제에서 '고슴도치는 물이 찰 예정인 칸으로 이동할 수 없다. 즉, 다음 시간에 물이 찰 예정인 칸으로 고슴도치는 이동할 수 없다.' 라고 했으므로 물에 관한 BFS를 먼저 실행시켜 물이 찬 다음 고슴도치를 움직여야 할 것이다.

 

* waterBFS()

int size에 waterQ의 사이즈를 저장해두고, size만큼 반복문을 돌리며 상하좌우 물의 영역을 넓혀나간다. 이 때 넓힌 영역의 위치를 waterQ에 넣는다.

 

* animalBFS()

임시의 큐 tmpQ를 준비한다. Q를 다 비울 때 까지 반복문을 돌며 고슴도치가 갈 수 있는 곳을 방문하고, 그 때의 위치를 tmpQ에 넣는다.

마지막에 Q = tmpQ 해서 복사한다.

 

# Code </>

public class Main {

    static class Point{
        int y, x;
        public Point(int yy, int xx){
            y=yy; x=xx;
        }
    }

    static int r, c, time = 0;
    static boolean flag;

    static int[] Y = {-1, 1, 0, 0}, X = {0, 0, -1, 1};
    static char[][] map = new char[51][51];
    static boolean[][] visit = new boolean[51][51];
    static Queue<Point> waterQ = new LinkedList<>(), Q = new LinkedList<>();

    static void waterBFS(){

        int size = waterQ.size();

        for(int i=0; i<size; i++){
            Point p = waterQ.poll();
            int y = p.y;
            int x = p.x;

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

                if(ny < 1 || nx < 1 || ny > r || nx > c || map[ny][nx] == 'D' || map[ny][nx] == 'X' || map[ny][nx] == '*') continue;

                map[ny][nx] = '*';
                waterQ.add(new Point(ny, nx));
            }
        }
    }
    static void animalBFS(){

        Queue<Point> tmpQ = new LinkedList<>();

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

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

                if (ny < 1 || nx < 1 || ny > r || nx > c || visit[ny][nx] || map[ny][nx] == 'X' || map[ny][nx] == '*') continue;

                if(map[ny][nx] == 'D') flag = true;

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

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

        r = Integer.parseInt(st.nextToken());
        c = Integer.parseInt(st.nextToken());

        for(int i=1; i<=r; i++){
            char[] str = br.readLine().toCharArray();
            for(int j=1; j<=c; j++){
                map[i][j] = str[j-1];
                
                if(map[i][j] == 'S') {
                    visit[i][j] = true;
                    Q.add(new Point(i, j));
                }
                
                else if(map[i][j] == '*')
                    waterQ.add(new Point(i, j));
            }
        }

        while(true){
            time++;
            waterBFS();
            animalBFS();

            if(flag) break;
            if(Q.size() == 0){
                System.out.println("KAKTUS");
                System.exit(0);
            }
        }
        System.out.println(time);
    }
}
반응형

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

[백준] 16234번 : 인구 이동  (0) 2021.02.09
[백준] 1325번 : 효율적인 해킹  (0) 2021.02.09
[백준] 1162번 : 도로 포장  (0) 2021.02.08
[백준] 1010번 : 다리 놓기  (0) 2021.02.06
[백준] 2294번 : 동전 2  (0) 2021.02.06
Comments