哈希表
思路
- 遍历数组
arr
,并用map
记录各元素出现的次数 - 根据map的key把对应的value提出 并保存在数组
val
中。(KeySet()
获取map中所有的key) - 遍历排序后的数组
val
,同时与k
比较,更新k
的值
代码
//55ms
public static int findLeastNumOfUniqueInts(int[] arr, int k) {
Map<Integer, Integer> map = new HashMap<>();
for (int num : arr) {
map.put(num, map.getOrDefault(num, 0) + 1);
}
if (k == 0) return map.size();
int[] val = new int[map.size()];
int i = 0;
for (int key : map.keySet()) {//获取map的所有key 并遍历
val[i++] = map.get(key);
}
Arrays.sort(val);
int j;
for (j = 0; j < val.length; j++) {
if (k - val[j] >= 0) {
k = k - val[j];
} else break;
}
return val.length - j;//妙!!!
}
参考链接