Coding Test/beakjoon

[백준/Java] 11000번 - 강의실 배정

굠민 2024. 9. 17. 11:01
문제 & 난이도

  • 그리디 알고리즘
  • 난이도 : 골드 5

 

풀이
package greedy;

import java.util.*;

public class Beakjoon11000 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);

        //첫째 줄 : 수업의 개수 N
        int N = sc.nextInt();

        //수업 시간을 저장할 배열
        int[][] timesheet = new int[N][2];

        //이후 N개의 줄 : 시작 시간과 끝나는 시간
        for (int i = 0; i < N; i++) {
                timesheet[i][0] = sc.nextInt(); //시작 시간 저장
                timesheet[i][1] = sc.nextInt(); //끝나는 시간 저장
        }

        //정렬 - 시작 시간 기준
        Arrays.sort(timesheet, new Comparator<int[]>() {
            @Override
            public int compare(int[] o1, int[] o2) {
                return o1[0] - o2[0];
            }
        });

        //우선순위 큐 이용 - 강의실 끝나는 시간 관리
        PriorityQueue<Integer> pq = new PriorityQueue<>();

        //첫 수업의 끝나는 시간 추가
        pq.add(timesheet[0][1]);

        //강의실 배정
        for (int i = 1; i < N; i++) {
            //강의실 재사용이 가능한 경우
            if(pq.peek() <= timesheet[i][0]) {
                pq.poll();
            }
            //추가 강의실이 필요한 경우
            pq.add(timesheet[i][1]);
        }

        //큐의 사이즈(강의실의 개수)출력
        System.out.println(pq.size());

    }
}

 

: 우선순위 큐를 사용하여 가장 먼저 끝나는 수업을 찾고, 추가 강의실이 필요한 경우 해당 수업을 큐에서 빼는 알고리즘

 

알게 된 것 & 느낀 점

 

우선순위 큐 : 가장 작은/큰 값이 가장 먼저 나오도록 정렬된 상태로 유지되는 자료구조.

(만약, 수업 끝나는 시간이 [2,3,5]로 저장되어 있으면 해당 코드에서 가장 먼저 나오는 값은 가장 작은 값인 2이다.)

 

 

 

 

 

'Coding Test > beakjoon' 카테고리의 다른 글

[백준/Java] 1083번 - 소트  (0) 2024.09.23
[백준/Java] 12904번 - A와 B  (3) 2024.09.19
[백준/Java] 9012번 - 괄호  (0) 2024.09.17
[백준/Java] 1931번 - 회의실 배정  (0) 2024.09.16
[백준/Java] 2285번 - 우체국  (2) 2024.09.16