Leetcode 独一无二的出现次数

可以通过哈希集来判断是否独一无二,如果set中已经包含了count,那么set.add(count)会返回false

java 复制代码
class Solution {
    public boolean uniqueOccurrences(int[] arr) {
        Map<Integer, Integer> map = new HashMap<>();
        for(int i = 0; i < arr.length; i++) {
            map.put(arr[i], map.getOrDefault(arr[i], 0) + 1);
        }
        //然后创建一个set统计是否独一无二
        Set<Integer> set = new HashSet<>();
        for(int count : map.values()) {
            if(!set.add(count)) {
                return false;
            }
        }
        return true;
    }
}

map.values() 会返回这个 Map 中所有 value(值) 的一个Collection视图 ,也就是说,它返回的是所有"出现次数"组成的集合(但不是 Set,而是一个 Collection)。

举个例子:

java 复制代码
Map<Integer, Integer> map = new HashMap<>();
map.put(1, 3);
map.put(2, 2);
map.put(3, 1);

Collection<Integer> values = map.values();
System.out.println(values);

输出结果为:

复制代码
[3, 2, 1]

注意几点:

  • map.values() 返回的是 Collection<Integer> 类型,不是 List 也不是 Set

  • 这个 Collection 是一个视图,和 Map 是关联的,如果你修改这个 CollectionMap 也会变;

  • 如果 map 中有重复的值,map.values() 也会反映出这些重复,例如:

    java 复制代码
    map.put(4, 3);

    此时 values 变为 [3, 2, 1, 3]

应用场景:

  • 如果你只是想遍历所有的 value,for (int v : map.values()) 是很常用的;
  • 如果你想判断这些 value 是否都不相同,通常会结合 Set 来做唯一性检查(如你这题中的场景)。
相关推荐
啊哦呃咦唔鱼5 分钟前
LeetCode hot100-240搜索二维矩阵 II
算法
Q741_1476 分钟前
力扣高频面试题详解 数组 链表 力扣 56.合并区间 力扣 160.相交链表 C++ 每日练习
c++·算法·leetcode·链表·数组·哈希
2301_7938046914 分钟前
C++中的备忘录模式
开发语言·c++·算法
ab15151716 分钟前
3.23完成进阶45、84,二刷基础132、129
算法·深度优先·图论
CoovallyAIHub17 分钟前
编码智能体做 CV 任务,实际能力到哪一步了?——五项视觉任务实测解读
深度学习·算法·计算机视觉
2501_9454235419 分钟前
C++编译期多态实现
开发语言·c++·算法
2401_8796938719 分钟前
设计模式在C++中的实现
开发语言·c++·算法
☆56623 分钟前
C++中的代理模式高级应用
开发语言·c++·算法
2301_8184190124 分钟前
编译器命令选项优化
开发语言·c++·算法
m0_5180194824 分钟前
C++图形编程(OpenGL)
开发语言·c++·算法