forked from onlybooks/java-algorithm-interview
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathP96_1.java
39 lines (35 loc) · 1.55 KB
/
P96_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
package ch24;
import java.util.*;
public class P96_1 {
public int[] solution(String[] id_list, String[] report, int k) {
// 가장 먼저 로그에서 중복 제거
Set<String> reportSet = new HashSet<>(Arrays.asList(report));
// 피신고자 / 신고자 목록
Map<String, List<String>> reportLog = new HashMap<>();
for (String set : reportSet) {
// 앞: 신고자, 뒤: 피신고자
String[] person = set.split(" ");
// 첫 신고라면 빈 리스트 생성
List<String> list = reportLog.getOrDefault(person[1], new ArrayList<>());
list.add(person[0]); // 신고자 목록에 삽입
// 피신고자 / 신고자 목록 삽입
reportLog.put(person[1], list);
}
// 신고자 / 메일 수
Map<String, Integer> mailCounts = new HashMap<>();
for (Map.Entry<String, List<String>> log : reportLog.entrySet()) {
// 신고자 목록이 k 이상일 때 신고자 목록 처리
if (log.getValue().size() >= k) {
for (String people : log.getValue()) {
// 모든 신고자 메일 +1
mailCounts.put(people, mailCounts.getOrDefault(people, 0) + 1);
}
}
}
// 스트림 API로 입력 배열을 메일 카운트 맵과 매칭하여 정답 구성
return Arrays.stream(id_list)
.map(x -> mailCounts.getOrDefault(x, 0))
.mapToInt(Integer::valueOf)
.toArray();
}
}