forked from onlybooks/java-algorithm-interview
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathP98_1.java
56 lines (49 loc) · 2.23 KB
/
P98_1.java
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
package ch24;
import java.util.*;
public class P98_1 {
public int[] solution(int[] fees, String[] records) {
Map<String, Integer> parkingLogs = new HashMap<>(); // 출입 내역
Map<String, Integer> parkingTimes = new HashMap<>(); // 누적 주차 시간
// 누적 주차 시간 계산
for (String record : records) {
String[] log = record.split(" ");
String[] time = log[0].split(":");
if (log[2].equals("IN")) {
parkingLogs.put(log[1],
Integer.parseInt(time[0]) * 60 + Integer.parseInt(time[1]));
} else {
// 출차일 때 분 단위로 시간을 계산하고 기존에 시간이 있다면 누적
int elapsedTime =
Integer.parseInt(time[0]) * 60 + Integer.parseInt(time[1]) - parkingLogs.get(log[1]);
parkingTimes.put(log[1], parkingTimes.getOrDefault(log[1], 0) + elapsedTime);
parkingLogs.remove(log[1]);
}
}
// 남아 있는 내역은 23:59로 계산
for (Map.Entry<String, Integer> parkingLog : parkingLogs.entrySet()) {
parkingTimes.put(parkingLog.getKey(),
parkingTimes.getOrDefault(parkingLog.getKey(), 0) +
23 * 60 + 59 - parkingLog.getValue());
}
// 키만 추출하여 정수형 기준으로 정렬
List<String> parkingTimesByKey = new ArrayList<>(parkingTimes.keySet());
parkingTimesByKey.sort(Comparator.comparingInt(Integer::parseInt));
// 정렬 키 기준으로 비용 계산하여 정답 구성
int[] answer = new int[parkingTimesByKey.size()];
int i = 0;
for (String k : parkingTimesByKey) {
int fee;
// 기본 시간 이내인 경우 기본 요금
if (parkingTimes.get(k) <= fees[0])
fee = fees[1];
else {
// 초과분은 단위 시간당 단위 요금으로 계산
fee = fees[1] +
(int) Math.ceil((float) (parkingTimes.get(k) - fees[0]) / fees[2]) * fees[3];
}
answer[i] = fee;
i++;
}
return answer;
}
}