存在重复元素

问题

给你一个整数数组 nums 。如果任一值在数组中出现 至少两次 ,返回 true ;如果数组中每个元素互不相同,返回 false 。

  • 示例

    1. 示例 1:
      输入:nums = [1,2,3,1]
      输出:true
    2. 示例 2:
      输入:nums = [1,2,3,4]
      输出:false
    3. 示例 3:
      输入:nums = [1,1,1,3,3,4,3,2,4,2]
      输出:true
  • 提示

    1 <= nums.length <= 105
    -109 <= nums[i] <= 109

  • 来源

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


解法一:lastIndexOf

// 可以使用indexOf和lastIndexOf,例如[1,2,1],indexOf(1)它会返回0,lastIndexOf(1)返回1,返回值不同说明该元素至少重复2次。
// const repeatValidate1 = (arr) => {
//     for(var i=0; i<arr.length; i++){
//         // 此时arr.indexOf(arr[i])等于遍历的数组的索引i   
//         if(i !== arr.lastIndexOf(arr[i])){
//             return true
//         }
//     }
//     return false
// }
// console.log(repeatValidate1([1,2,1,4]));

企业微信截图_16526661434439

解法二:排序后比较相邻元素

// 先给数组排序,如果数组存在重复的元素则数组中一定有相同的相邻元素
// const repeatValidate2 = (arr) => {
//     arr = arr.sort()
//     for(var i=0; i<arr.length; i++){  
//         // 防止数组越界,当判断倒数第二个元素时,其实倒数第一个元素已经进行了判断,所以当i+1 >= arr.length时已经判断完成
//         if((i+1) >= arr.length) return false

//         if(arr[i] === arr[i+1]) return true
//     }
// }
// console.log(repeatValidate2([1,2,5,4]));

企业微信截图_16526708521421

解法三:Map

// 使用Map,遍历数组,向map存值,在存值之前先查看map有没有该元素,如果有则数组中有重复的,没有就存值。
// const repeatValidate3 = (arr) => {
//     const map = new Map()
//     const len = arr.length
//     var i = 0
//     var flag = false  // 默认不存在重复,返回false
//     while(!flag && i<len){
//         if(map.has(arr[i])){
//             flag = true
//             break
//         }else {
//             // map以键值对的方式存在,查找速率很快,这里我们是用他的键进行判断
//             map.set(arr[i], true)
//             i++
//         }
//     }
//     return flag
// }
// console.log(repeatValidate3([1,2,1,4]));

企业微信截图_16526792001374

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值