-
[CS & Algorithm-7] 회의실 배정 (Greedy)CS & Algorithm 2021. 8. 19. 22:50
BaekJoon Online Judge 1931
Question :https://www.acmicpc.net/problem/1931
Source :https://github.com/lee-maru/practice_algorithm/blob/master/src/Solution4.java
/** * 문제 * 한 개의 회의실이 있는데 이를 사용하고자 하는 N개의 회의에 대하여 회의실 사용표를 만들려고 한다. 각 회의 I에 대해 시작시간과 끝나는 시간이 주어져 있고, 각 회의가 겹치지 않게 하면서 회의실을 사용할 수 있는 회의의 최대 개수를 찾아보자. 단, 회의는 한번 시작하면 중간에 중단될 수 없으며 한 회의가 끝나는 것과 동시에 다음 회의가 시작될 수 있다. 회의의 시작시간과 끝나는 시간이 같을 수도 있다. 이 경우에는 시작하자마자 끝나는 것으로 생각하면 된다. * * 입력 * 첫째 줄에 회의의 수 N(1 ≤ N ≤ 100,000)이 주어진다. 둘째 줄부터 N+1 줄까지 각 회의의 정보가 주어지는데 이것은 공백을 사이에 두고 회의의 시작시간과 끝나는 시간이 주어진다. 시작 시간과 끝나는 시간은 231-1보다 작거나 같은 자연수 또는 0이다. * * 출력 * 첫째 줄에 최대 사용할 수 있는 회의의 최대 개수를 출력한다. * * 예제 입력 1 * 11 * 1 4 * 3 5 * 0 6 * 5 7 * 3 8 * 5 9 * 6 10 * 8 11 * 8 12 * 2 13 * 12 14 * 예제 출력 1 * 4 ```java
import java.util.ArrayList; import java.util.List; import java.util.Scanner; public class Solution4 { static class TimeTable implements Comparable{ Integer start; // 시작 시간 Integer end;// 종료시간 public TimeTable(Integer start, Integer end){ this.start = start; this.end = end; } public int compareTo(TimeTable otherTimeTable){ if (this.end > otherTimeTable.end) { // 끝나는 시간 기준 오름차순 정렬 return 1; } else if (this.end.equals(otherTimeTable.end)) { if(this.start > otherTimeTable.start) { // 끝나는 시간 같다면 시작 시간 기준 오름차순 return 1; } else { return -1; } } else { return -1; } } } public static void main(String[] args) { Scanner sc = new Scanner(System.in); int N = sc.nextInt(); int result = 0; int endTime = 0; List<TimeTable> rooms = new ArrayList<>(); for (int i =0; i<N; i++){ rooms.add(new TimeTable(sc.nextInt(), sc.nextInt())); } rooms.sort(((o1, o2) -> o1.compareTo(o2))); for (int i = 0; i < rooms.size(); i++) { if(endTime <= rooms.get(i).start){ endTime = rooms.get(i).end; result++; } } System.out.println(result); } }
'CS & Algorithm' 카테고리의 다른 글
[CS & Algorithm-9] 거스름돈 (Greedy) (0) 2021.08.19 [CS & Algorithm-8] 잃어버린 괄호 (Greedy) (0) 2021.08.19 [CS & Algorithm-6] 동전 0 (Greedy) (0) 2021.08.18 [CS & Algorithm-5] BaekJoon 설탕 배달 문제 (Greedy) (0) 2021.08.18 [CS & Algorithm-4] BaekJoon ATM 문제 (Greedy) (0) 2021.08.18