「优选算法刷题」:存在重复元素

一、题目

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

示例 1:

复制代码
输入:nums = [1,2,3,1]
输出:true

示例 2:

复制代码
输入:nums = [1,2,3,4]
输出:false

示例 3:

复制代码
输入:nums = [1,1,1,3,3,4,3,2,4,2]
输出:true

提示:

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

二、思路解析

判断一个数组是否有重复元素,也是一道比较基础的算法题,考验的是对容器的使用。

首先,我们先明确好题目的要求:只要数组中有任意两个元素相等,就返回 true;否则,返回 false。

而这个要求,用哈希表来实现刚刚好。

具体实现,我们遍历先数组,对于每个元素,如果它已经在哈希表中出现过了,则说明数组中有重复元素,直接返回 true;否则,将该元素添加到哈希表中。最后,如果遍历完整个数组都没有发现重复元素,则返回 false。

同时,罗根在做这类题的时候,常常忘记下面这一步操作:

复制代码
hash.add(x); // 将哈希表中还不存在的元素添加到哈希表中

在这里也提醒一下大家。,if 判断后千万不要忘记这一步。

三、完整代码

复制代码
class Solution {
    public boolean containsDuplicate(int[] nums) {
        Set<Integer> hash = new HashSet<>();
        for(int x : nums){
            if(hash.contains(x)){
                return true;
            }
            hash.add(x);
        }
        return false;
    }
}

以上就是本篇博客的全部内容啦,如有不足之处,还请各位指出,期待能和各位一起进步!

相关推荐
AI机器学习算法10 小时前
机器学习基础知识
数据结构·人工智能·python·深度学习·算法·机器学习·ai学习路线
坚果派·白晓明16 小时前
【鸿蒙PC三方库移植适配框架解读系列】第八篇:扩展lycium框架使其满足rust三方库适配
c语言·开发语言·华为·rust·harmonyos·鸿蒙
花间相见16 小时前
【PaddleOCR教程01】PP-OCRv5 全面指南:从模型架构到实战部署
开发语言·r语言
X journey17 小时前
机器学习进阶(13):支持向量机SVM
算法·机器学习·支持向量机
小短腿的代码世界17 小时前
Qt 股票订单撮合引擎:高频交易系统的核心心脏
开发语言·数据库·qt·系统架构·交互
洛水水17 小时前
【力扣100题】30.二叉树的直径
算法·leetcode·职场和发展
gihigo199818 小时前
Bezier曲线曲面生成算法
算法
刀法如飞18 小时前
Ontology本体论是什么数据结构?Palantir 技术原理介绍
数据结构·人工智能·ai编程·图论
平行侠18 小时前
024多精度大整数 - 突破硬件精度限制的任意精度运算
数据结构·算法
谙弆悕博士18 小时前
快速学C语言——第16章:预处理
c语言·开发语言·chrome·笔记·创业创新·预处理·业界资讯