ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • [Baekjoon Online Judge] 2468번: 안전 영역
    문제 풀이/Baekjoon Online Judge 2021. 1. 20. 20:17
     

    2468번: 안전 영역

    재난방재청에서는 많은 비가 내리는 장마철에 대비해서 다음과 같은 일을 계획하고 있다. 먼저 어떤 지역의 높이 정보를 파악한다. 그 다음에 그 지역에 많은 비가 내렸을 때 물에 잠기지 않는

    www.acmicpc.net

    요구사항

     - 어떤 지역의 높이를 파악한다.

     - 그 지역에 많은 비가 내렸을 때 물에 잠기지 않는 안전한 영역이 최대로 몇 개 만들어 지는 지를 조사한다.

     - 장마철에 내리는 비의 양에 따라 일정한 높이 이하의 모든 지점은 물에 잠긴다.

     - 어떤 지역의 높이 정보가 주어졌을 때, 장마철에 물에 잠기지 않는 안전한 영역의 최대 개수를 계산한다.

     - 단, 아무 지역도 물에 잠기지 않을 수도 있다. 높이가 0 이하 일 때

    입력

     첫째 줄에는 어떤 지역을 나타내는 2차원 배열의 행과 열의 개수를 나타내는 수 N이 입력된다. N은 2 이상 100 이하의 정수이다. 둘째 줄부터 N개의 각 줄에는 2차원 배열의 첫 번째 행부터 N번째 행까지 순서대로 한 행씩 높이 정보가 입력된다. 각 줄에는 각 행의 첫 번째 열부터 N번째 열까지 N개의 높이 정보를 나타내는 자연수가 빈 칸을 사이에 두고 입력된다. 높이는 1이상 100 이하의 정수이다.

    출력

     첫째 줄에 장마철에 물에 잠기지 않는 안전한 영역의 최대 개수를 출력한다.


    import java.io.BufferedReader;
    import java.io.BufferedWriter;
    import java.io.IOException;
    import java.io.InputStreamReader;
    import java.io.OutputStreamWriter;
    import java.util.LinkedList;
    import java.util.Queue;
    
    public class Baekjoon2468 {
    
        static int n;
        static int[][] map;
        static int[][] rainMap;
        static boolean[][] visited;
        static int[] xMove = {-1, 1, 0, 0};
        static int[] yMove = {0, 0, -1, 1};
        static int count;
        static int max;
    
        static class Location {
            int x, y;
    
            public Location(int x, int y) {
                this.x = x;
                this.y = y;
            }
        }
    
        private static void bfs(int startX, int startY) {
            Queue<Location> queue = new LinkedList<>();
            queue.add(new Location(startX, startY));
            visited[startX][startY] = true;
    
            while (!queue.isEmpty()) {
                Location location = queue.poll();
                int pollX = location.x;
                int pollY = location.y;
    
                for (int i = 0; i < 4; i++) {
                    int x = pollX + xMove[i];
                    int y = pollY + yMove[i];
    
                    if (isLocation(x, y)) {
                        queue.add(new Location(x, y));
                        visited[x][y] = true;
                    }
                }
            }
        }
    
        private static boolean isLocation(int x, int y) {
            if (x >= 0 && y >= 0 && x < n && y < n && rainMap[x][y] == 1 && !visited[x][y]) return true;
            return false;
        }
    
        private static void createRainMap(int height) {
            rainMap = new int[n][n];
            visited = new boolean[n][n];
    
            for (int i = 0; i < n; i++) {
                for (int j = 0; j < n; j++) {
                    if (map[i][j] <= height) rainMap[i][j] = 0;
                    else rainMap[i][j] = 1;
                }
            }
    //        print();
        }
    
        private static void print() {
            for (int i = 0; i < n; i++) {
                for (int j = 0; j < n; j++) {
                    System.out.print(rainMap[i][j] + " ");
                }
                System.out.println();
            }
            System.out.println();
        }
    
        public static void main(String[] args) throws IOException {
    
            BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(System.in));
            BufferedWriter bufferedWriter = new BufferedWriter(new OutputStreamWriter(System.out));
    
            n = Integer.parseInt(bufferedReader.readLine());
    
            map = new int[n][n];
            rainMap = new int[n][n];
    
            int height = 0;
            for (int i = 0; i < n; i++) {
                String[] input = bufferedReader.readLine().split(" ");
                for (int j = 0; j < n; j++) {
                    map[i][j] = Integer.parseInt(input[j]);
                    height = Math.max(height, map[i][j]);
                }
            }
    
            for (int h = 0; h <= height; h++) {
                createRainMap(h);
                count = 0;
                for (int i = 0; i < n; i++) {
                    for (int j = 0; j < n; j++) {
                        if (rainMap[i][j] == 1 && !visited[i][j]) {
                            bfs(i, j);
                            ++count;
                        }
                    }
                }
                max = Math.max(max, count);
            }
    
            bufferedWriter.write(String.valueOf(max));
    
            bufferedWriter.flush();
            bufferedReader.close();
            bufferedWriter.close();
        }
    }

     

     문제 자체를 풀이하는데는 어렵지 않았다. 높이마다 새롭게 map을 그려서 bfs로 탐색하고 안전지역의 개수를 count하였다. 하나 실수한 점이 비가 안올 때, 즉 높이가 0이하 일 때를 고려하지 못하여 관련 내용을 수정하는데 많은 시간이 걸렸다.

    댓글

Designed by Tistory.