题目

给定一个整数数组,判断是否存在重复元素。

如果任意一值在数组中出现至少两次,函数返回 true 。如果数组中每个元素都不相同,则返回 false.

示例 1:

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

示例 2:

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

示例 3:

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

来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/contains-duplicate

题解

思路一

直接用hash map 标记出现过的数字,遍历整个数据,每次检查是否出现过。

  • 时间复杂度: O(n)
  • 空间复杂度: O(n)
func containsDuplicate(nums []int) bool {
    m := make(map[int]bool)
    for _, i := range nums {
        if m[i] {
            return true
        }
        m[i] = true
    }
    return false
}

思路二

先排序数组,再利用^位操作判定是否存在重复数字。

  • 时间复杂度: O(n)
  • 空间复杂度: O(1)
func containsDuplicate(nums []int) bool {
	sort.Ints(nums)
	for i:=1;i<len(nums);i++{
		if nums[i-1] ^ nums[i] == 0 {
			return true
		}
	}
	return false
}