forked from onlybooks/java-algorithm-interview
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathP33_1.java
47 lines (43 loc) · 2.17 KB
/
P33_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
package ch11;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class P33_1 {
public int[] topKFrequent(int[] nums, int k) {
// 각 엘리먼트의 빈도수를 저장할 해시맵 선언, 엘리먼트=>빈도수
Map<Integer, Integer> frequencyMap = new HashMap<>();
// 각 엘리먼트의 빈도수를 반복하며 계산하여 저장
for (int n : nums) {
// 처음 빈도수를 계산하는 엘리먼트는 기본값 0으로, 모두 +1 하여 저장
frequencyMap.put(n, frequencyMap.getOrDefault(n, 0) + 1);
}
// 빈도수 기준으로 각 엘리먼트를 저장할 해시맵 선언, 빈도수=>엘리먼트
Map<Integer, List<Integer>> buckets = new HashMap<>();
// 각 엘리먼트를 반복하며 이번에는 빈도수를 키로, 엘리먼트를 값으로 저장
for (int elem : frequencyMap.keySet()) {
int frequency = frequencyMap.get(elem);
// 빈도수에 해당하는 엘리먼트가 존재하지 않으면 빈 리스트 생성
List<Integer> elems = buckets.getOrDefault(frequency, new ArrayList<>());
// 저장할 값에 엘리먼트 추가
elems.add(elem);
// 빈도수를 키로 엘리먼트를 값으로 저장
buckets.put(frequency, elems);
}
// 결과로 리턴할 변수 선언, k번까지만 추출하면 되므로 k 만큼 선언
int[] result = new int[k];
int index = 0;
// 전체 엘리먼트 수에서 하나씩 내려가며 해당하는 빈도의 엘리먼트 추출
for (int frequency = nums.length; frequency >= 0 && index < k; frequency--) {
// 해당 빈도에 값이 존재한다면 엘리먼트를 결과 변수에 삽입
if (buckets.get(frequency) != null) {
// 해당 빈도에 여러 엘리먼트가 있을 수 있으므로 반복하여 모두 삽입
for (int elem : buckets.get(frequency)) {
result[index] = elem;
index++;
}
}
}
return result;
}
}