All prompts are owned by LeetCode. To view the prompt, click the title link above.
First completed : June 27, 2024
Last updated : June 27, 2024
Related Topics : Array, Hash Table, Sliding Window
Acceptance Rate : 71.4 %
class Solution {
public int[] distinctNumbers(int[] nums, int k) {
int[] output = new int[nums.length - k + 1];
HashMap<Integer, Integer> window = new HashMap<>();
for (int i = 0; i < k - 1; i++) {
window.put(nums[i], window.getOrDefault(nums[i], 0) + 1);
}
for (int i = k - 1; i < nums.length; i++) {
window.put(nums[i], window.getOrDefault(nums[i], 0) + 1);
output[i - k + 1] = window.size();
if (window.get(nums[i - k + 1]) == 1) {
window.remove(nums[i - k + 1]);
} else {
window.put(nums[i - k + 1], window.get(nums[i - k + 1]) - 1);
}
}
return output;
}
}