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

存在重复元素

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

class Solution {

   public boolean containsDuplicate(int[] nums) {

   }

}

示例 1:
输入: [1,2,3,1]
输出: true

示例 2:
输入: [1,2,3,4]
输出: false

示例 3:
输入: [1,1,1,3,3,4,3,2,4,2]
输出: true

方式一:效率低

class Solution {
    public boolean containsDuplicate(int[] nums) {
        for(int i=0;i

方式二:

static class Solution {
        public boolean containsDuplicate(int[] nums) {
            Set set = new HashSet();
            for (int x : nums) {
                if (!set.add(x)) {
                    return true;
                }
            }
            return false;
        }
    }

方式三:

static class Solution {
       
        public boolean containsDuplicate(int[] nums) {

            HashSet set = new HashSet();
            for (int i = 0; i < nums.length; i++) {
                if (set.contains(nums[i])) {
                    return true;
                } else {
                    //如果此set已经包含该元素,则该调用不改变此set并返回false
                    set.add(nums[i]);
                }

            }
            return false;
        }
    }

你可能感兴趣的:(JavaSE练习,后端,java,算法)