• [15686] 백준 - 치킨배달(JAVA)

    2021. 10. 19.

    by. 데롱디롱

    728x90

     

     

    [ 문제 풀이 ]

    - 도시 상황을 입력 받으면서, 치킨집의 좌표도 ArrayList에 함께 저장

    - ArrayList에 저장되어있는 치킨집을 M개 선택하는 경우의 수를 구한다.

    - 각 집에서, M개 선택한 치킨 집 중 가까운 것의 거리의 합을 구한다.

    - min과 비교해서 가장 작은 치킨 거리를 저장해둔다.

    - 치킨집을 M개 선택하는 모든 경우에 대해 치킨 거리를 모두 구하면, 그 중 최소의 거리가 저장되어있는 min을 출력한다.

     

     

     

     

     

     

    [ 전체 코드 ]

    import java.io.BufferedReader;
    import java.io.IOException;
    import java.io.InputStreamReader;
    import java.util.ArrayList;
    import java.util.StringTokenizer;
    
    public class Main {
        static int N, M, min = Integer.MAX_VALUE;
        static ArrayList<int[]> chickenStore;
        static int isSelected[], city[][];
    
        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());
            M = Integer.parseInt(st.nextToken());
    
            city = new int[N][N];
            chickenStore = new ArrayList<int[]>();
            for (int r = 0; r < N; r++) {
                st = new StringTokenizer(br.readLine());
                for (int c = 0; c < N; c++) {
                    city[r][c] = Integer.parseInt(st.nextToken());
                    if (city[r][c] == 2)
                        chickenStore.add(new int[]{r, c});
                }
            }
    
            isSelected = new int[M];
            comb(0, 0);
    
            System.out.println(min);
        }
    
        // 치킨 집 고르기
        private static void comb(int cur, int cnt) {
            if (cnt == M) {
                min = Math.min(min, checkLength());
                return;
            }
    
            for (int i = cur; i < chickenStore.size(); i++) {
                isSelected[cnt] = i;
                comb(i + 1, cnt + 1);
            }
        }
    
        // 치킨 거리 구하기
        private static int checkLength() {
            int sum = 0;
    
            for (int r = 0; r < N; r++) {
                for (int c = 0; c < N; c++) {
                    if (city[r][c] == 1) {
                        int min_length = Integer.MAX_VALUE;
                        for (int k = 0; k < M; k++) {
                            int[] chicken = chickenStore.get(isSelected[k]);
                            int d = Math.abs(r - chicken[0]) + Math.abs(c - chicken[1]);
                            min_length = Math.min(min_length, d);
                        }
                        sum += min_length;
                    }
                }
            }
    
            return sum;
        }
    }

    댓글