-
Notifications
You must be signed in to change notification settings - Fork 17
Expand file tree
/
Copy pathMostFrequentEvenElement.java
More file actions
29 lines (24 loc) · 929 Bytes
/
MostFrequentEvenElement.java
File metadata and controls
29 lines (24 loc) · 929 Bytes
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
// https://leetcode.com/problems/most-frequent-even-element
// T: O(N)
// S: O(N)
import java.util.HashMap;
import java.util.Map;
public class MostFrequentEvenElement {
public int mostFrequentEven(int[] nums) {
final Map<Integer, Integer> evenFrequencies = new HashMap<>();
int maxFrequency = 0, smallestEvenNumber = -1;
for (int element : nums) {
if (element % 2 == 1) {
continue;
}
evenFrequencies.put(element, evenFrequencies.getOrDefault(element, 0) + 1);
if (evenFrequencies.get(element) > maxFrequency) {
maxFrequency = evenFrequencies.get(element);
smallestEvenNumber = element;
} else if (evenFrequencies.get(element) == maxFrequency) {
smallestEvenNumber = Math.min(smallestEvenNumber, element);
}
}
return smallestEvenNumber;
}
}