티스토리 뷰

반응형


#. Problem

* The copyright in this matter is in BOJ


#. Resolution Process

  1. Read and understand problem

  2. Redefine the problem + abstract

  3. Create solution plan (select Algorithm, Data structure)

  4. Prove the plan (check performance time and usage memory)

  5. Carry out the plan

  6. Look back on the plan and find a way to improve it


#. Solve


종료시간 기준으로 정렬하는게 제일 중요한 포인트인것 같다.

여기서 다만 종료시간이 같을 경우 시작 시간이 빠른 순으로 

이중정렬(?)을 해주어야 했다.


#. Code

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Arrays;
import java.util.StringTokenizer;
 
public class BOJ1931 {
 
    static class info implements Comparable<info>{
        int start, end;
 
        public info(int start, int end) {
            this.start = start;
            this.end = end;
        }
 
        @Override
        public int compareTo(info o) {
            // 종료 시간이 같다면
            // 시작 시간 기준으로 정렬
            // 다르다면, 종료시간 기준으로 정렬
            if(this.end == o.end)
                return Integer.compare(this.start, o.start);
            else 
                return Integer.compare(this.end, o.end);
        }
    }
    
    public static void main(String[] args) throws IOException {
        
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        int N = Integer.parseInt(br.readLine());
        info[] timeLst= new info[N]; 
        // 회의 정보
        for (int i = 0; i < N; i++) {
            StringTokenizer st = new StringTokenizer(br.readLine(), " ");
            timeLst[i] = new info(Integer.parseInt(st.nextToken()), 
                    Integer.parseInt(st.nextToken()));
        }
            
        // 종료시간 기준 정렬
        Arrays.sort(timeLst);
        
        int cnt = 0;
        int now = 0;
        for(info t : timeLst) {
            // 시작 시간이 현재시간보다 이르다면 pass
            if(t.start < now) continue;
            now = t.end;    // 현재 시간을 종료 시간으로 갱신
            cnt++;
        }
        
        System.out.println(cnt);
    }
 
}
 
cs

반응형

'PS > Problem_Solving' 카테고리의 다른 글

[BOJ] 2164. 카드2(Queue).java  (0) 2020.08.08
[BOJ] 5568. 카드 놓기(조합).java  (0) 2020.08.08
[BOJ] 10026.적록색약.java  (0) 2020.08.07
[BOJ] 1068.트리.java  (0) 2020.08.07
[BOJ] 7576. 토마토(BFS).java  (0) 2020.08.06
댓글
최근에 올라온 글
최근에 달린 댓글
링크
Total
Today
Yesterday