[백준]_19583_싸이버개강총회

`map을 이용해 구현

처음부터 시뮬레이션 하듯이 스트리밍 전, 후~종료 에 대한 처리를 순차적으로 함.

아예 안 들어오는 경우를 생각 안 했다가 br.readline == null 을 넣고 해결


 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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.HashMap;
import java.util.Map;
import java.util.StringTokenizer;

public class B19583 {

	static int cnt = 0;
	static int[] time = new int[3];
	static StringTokenizer st, st1;

	public static void main(String[] args) throws IOException {
		int h=0, m=0;
		String rename=new String(), line=new String();

		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		
		st = new StringTokenizer(br.readLine(), " ");
		Map<String, Boolean> map = new HashMap<>();
		// map에 아이디와 중복 여부 판별을 위해 boolean을 넣음
		for (int i = 0; i < 3; i++) {
			st1 = new StringTokenizer(st.nextToken(), ":");
			h = Integer.parseInt(st1.nextToken());
			m = Integer.parseInt(st1.nextToken());
			time[i] = calTime(h,m);
		}
		
		// 스트리밍 시작 전 들어온 사람 map에 넣기
		while ((line = br.readLine()) != null) {
			st = new StringTokenizer(line, " ");
			st1 = new StringTokenizer(st.nextToken(), ":");
			h = Integer.parseInt(st1.nextToken());
			m = Integer.parseInt(st1.nextToken());

			if (calTime(h, m)<=time[0]) {
				map.put(st.nextToken(), false);
			}else {
				rename = st.nextToken();
				break;
			}
		}

		// 스트리밍 중 들어온 사람 처리 후 끝나고 들어온 사람이 있을 경우 넘어감
		if (calTime(h, m)< time[1]) {
			while ((line = br.readLine()) != null && calTime(h, m)< time[1]) {
				st = new StringTokenizer(line, " ");
				st1 = new StringTokenizer(st.nextToken(), ":");
				h = Integer.parseInt(st1.nextToken());
				m = Integer.parseInt(st1.nextToken());
				rename = st.nextToken();
			}
		}
		if (calTime(h, m)>= time[1] && calTime(h, m)<= time[2] && map.containsKey(rename)) {
			cnt++;
			map.put(rename, true);
		}
		
		// 스트리밍 끝 ~종료 때 있는 사람 체크
		while ((line = br.readLine()) != null) {
			st = new StringTokenizer(line, " ");
			st1 = new StringTokenizer(st.nextToken(), ":");
			h = Integer.parseInt(st1.nextToken());
			m = Integer.parseInt(st1.nextToken());
			if (calTime(h, m)>= time[1] && calTime(h, m)<= time[2]) {
				rename = st.nextToken();
				if (map.containsKey(rename) && !map.get(rename)) {
					cnt++;
					map.put(rename, true);
				}
			}else {
				break;
			}
		}
		System.out.println(cnt);
	}
	
	// 시간비교를 위함
	static int calTime(int hour, int min) {
		return hour*60 + min;
	}

}
updatedupdated2021-02-262021-02-26
Load Comments?