Skip to main content

存在重复元素

题意

给定一个整数数组,判断是否存在重复元素。
如果存在一值在数组中出现至少两次,函数返回 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

解法

通过哈希表缓存信息,当Map.has有命中时,代表有重复数字,结束查找。

/**
* @param {number[]} nums
* @return {boolean}
*/
var containsDuplicate = function(nums) {
const map = new Map();
let index = 0;
while(index < nums.length){
if(map.has(nums[index])){
return true;
}
map.set(nums[index], nums[index]);
index++;
}
return false;
};