leetcode-存在重复元素

  1. 存在重复元素
    题目链接:
    leetcode

给定一个整数数组,判断是否存在重复元素。
如果存在一值在数组中出现至少两次,函数返回 true 。
如果数组中每个元素都不相同,则返回 false 。

最简单的就是直接用哈希表,从左往右遍历,检测哈希表是否存在当前元素。
存在就直接返回false,不存在就加入哈希表。

    public boolean containsDuplicate(int[] nums) {
        HashSet<Integer> set = new HashSet<>();
        for (int x : nums) {
            if (!set.add(x)) {
                return true;
            }
        }
        return false;
    }

也可以给数组排序,然后判断相邻的两个元素是否重复

    public boolean containsDuplicate(int[] nums) {
        int n = nums.length;
        if(n==0||n==1){
            return false;
        }
        Arrays.sort(nums);
        for(int i = 0;i<n-1;i++){
            if(nums[i]==nums[i+1]){
                return true;
            }
        }
        return false;
    }

leetcode-存在重复元素

上一篇:Go使用反射递归复制结构体


下一篇:Chapter 10 Operator Overloading