[백준]#8972 미친 아두이노

SeungBird·2020년 8월 31일
0

⌨알고리즘(백준)

목록 보기
186/401
post-custom-banner

문제

요즘 종수는 아두이노를 이용해 "Robots"이라는 게임을 만들었다. 종수는 아두이노 한대를 조정하며, 미친 아두이노를 피해다녀야 한다. 미친 아두이노는 종수의 아두이노를 향해 점점 다가온다. 하지만, 미친 아두이노의 움직임은 예측할 수 있다.

게임은 R×C크기의 보드 위에서 이루어지며, 아래와 같은 5가지 과정이 반복된다.

  1. 먼저, 종수가 아두이노를 8가지 방향(수직,수평,대각선)으로 이동시키거나, 그 위치에 그대로 놔둔다.
  2. 종수의 아두이노가 미친 아두이노가 있는 칸으로 이동한 경우에는 게임이 끝나게 되며, 종수는 게임을 지게 된다.
  3. 미친 아두이노는 8가지 방향 중에서 종수의 아두이노와 가장 가까워 지는 방향으로 한 칸 이동한다. 즉, 종수의 위치를 (r1,s1), 미친 아두이노의 위치를 (r2, s2)라고 했을 때, |r1-r2| + |s1-s2|가 가장 작아지는 방향으로 이동한다.
  4. 미친 아두이노가 종수의 아두이노가 있는 칸으로 이동한 경우에는 게임이 끝나게 되고, 종수는 게임을 지게 된다.
  5. 2개 또는 그 이상의 미친 아두이노가 같은 칸에 있는 경우에는 큰 폭발이 일어나고, 그 칸에 있는 아두이노는 모두 파괴된다.

종수의 시작 위치, 미친 아두이노의 위치, 종수가 움직이려고 하는 방향이 주어진다. 입력으로 주어진 방향대로 종수가 움직였을 때, 보드의 상태를 구하는 프로그램을 작성하시오. 중간에 게임에서 지게된 경우에는 몇 번째 움직임에서 죽는지를 구한다.

입력

첫째 줄에 보드의 크기 R과 C가 주어진다. (1 ≤ R, C ≤ 100)

다음 R개 줄에는 C개의 문자가 주어지며, 보드의 상태이다. '.'는 빈 칸, 'R'은 미친 아두이노, 'I'는 종수의 위치를 나타낸다.

마지막 줄에는 길이가 100을 넘지않는 문자열이 주어지며, 종수가 움직이려고 하는 방향이다. 5는 그 자리에 그대로 있는 것을 나타내고, 나머지는 아래와 같은 방향을 나타낸다.

보드를 벗어나는 입력은 주어지지 않는다.

출력

중간에 게임이 끝나는 경우에는 "kraj X"를 출력한다. X는 종수가 게임이 끝나기 전 까지 이동한 횟수이다. 그 외의 경우에는 보드의 상태를 입력과 같은 형식으로 출력한다.

예제 입력 1

9 10
..........
.........R
..........
R.........
R...I.....
R.........
..........
.........R
....R.....
5558888

예제 출력 1

....I.....
....R.....
..........
..........
..........
..........
..........
..........
..........

풀이

이 문제는 BFS 알고리즘을 이용해서 풀 수 있었다.

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.IOException;
import java.util.LinkedList;
import java.util.Queue;

public class Main {
    static Queue<Pair> queue = new LinkedList<>();
    static Pair p;
    static String p_str;
    static int N;
    static int M;
    static int[][] map;
    static int[] dx = {0, 1, 1, 1, 0, 0, 0, -1, -1, -1};
    static int[] dy = {0, -1, 0, 1, -1, 0, 1, -1, 0, 1};

    public static void main(String[] args) throws IOException{
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        String[] input = br.readLine().split(" ");
        N = Integer.parseInt(input[0]);
        M = Integer.parseInt(input[1]);
        map = new int[N][M];

        for(int i=0; i<N; i++) {
            String str = br.readLine();
            for(int j=0; j<M; j++) {
                if(str.charAt(j)=='R') {
                    queue.add(new Pair(i, j));
                    map[i][j]++;
                }

                if(str.charAt(j)=='I')
                    p = new Pair(i, j);
            }
        }
        p_str = br.readLine();
        bfs();
    }

    public static void bfs() {
        int t = 0;

        while(t<p_str.length()) {
            int i = queue.size();
            if(map[p.x+dx[p_str.charAt(t)-'0']][p.y+dy[p_str.charAt(t)-'0']]==1) {
                System.out.println("kraj "+(t+1));
                return;
            }

            p = new Pair(p.x+dx[p_str.charAt(t)-'0'],p.y+dy[p_str.charAt(t)-'0']);
            map = new int[N][M];

            if(i>0) {
                for(int j=0; j<i; j++) {
                    Pair temp = queue.poll();
                    int min = Integer.MAX_VALUE;
                    Pair min_index = new Pair(0, 0);

                    for(int k=1; k<=9; k++) {
                        int nx = temp.x+dx[k];
                        int ny = temp.y+dy[k];

                        if(Math.abs(nx-p.x)+Math.abs(ny-p.y)<min) {
                            min = Math.abs(nx-p.x)+Math.abs(ny-p.y);
                            min_index = new Pair(nx, ny);
                        }
                    }

                    if(min_index.x==p.x && min_index.y==p.y) {
                        System.out.println("kraj "+(t+1));
                        return;
                    }
                    map[min_index.x][min_index.y]++;
                }

                for(int j=0; j<N; j++) {
                    for(int k=0; k<M; k++) {
                        if(map[j][k]==1)
                            queue.add(new Pair(j, k));
                    }
                }
            }

            t++;
        }

        for(int i=0; i<N; i++) {
            for(int j=0; j<M; j++) {
                if(i==p.x && j==p.y)
                    System.out.print("I");

                else if(map[i][j]==1)
                    System.out.print("R");

                else
                    System.out.print(".");
            }
            System.out.println();
        }
    }

    public static class Pair {
        int x;
        int y;

        public Pair(int x, int y) {
            this.x = x;
            this.y = y;
        }
    }
}
profile
👶🏻Jr. Programmer
post-custom-banner

0개의 댓글