leetcode算法217.存在重复元素

简介: 当给你一个整数数组 nums时 ,如果任一值在数组中出现 至少两次 ,如何返回 true ?如果数组中每个元素互不相同,如何返回 false ?本文带大家解决这些问题。

一、leetcode算法



1、存在重复元素


1.1、题目


给你一个整数数组 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.2、思路


思路一:此题我们可以使用一个hash表来存储数据,当出现存储的数据重复时直接返回true即可,如果没有出现重复数据则返回false。


1.3、答案


10.png


class Solution {
    public boolean containsDuplicate(int[] nums) {
        //定义一个hash表
        Set<Integer> set = new HashSet<Integer>();
        for(int x : nums){
            //如果hash存在相同的数据,则返回true
            if(!set.add(x)){
                return true;
            }
        }
        return false;
    }
}


复杂度分析


时间复杂度:O(N),其中 N 为数组的长度。


空间复杂度:O(N),其中 N 为数组的长度。

相关文章
【力扣】-- 移除链表元素
【力扣】-- 移除链表元素
160 1
|
2月前
|
存储 人工智能 算法
从零掌握贪心算法Java版:LeetCode 10题实战解析(上)
在算法世界里,有一种思想如同生活中的"见好就收"——每次做出当前看来最优的选择,寄希望于通过局部最优达成全局最优。这种思想就是贪心算法,它以其简洁高效的特点,成为解决最优问题的利器。今天我们就来系统学习贪心算法的核心思想,并通过10道LeetCode经典题目实战演练,带你掌握这种"步步为营"的解题思维。
|
8月前
|
机器学习/深度学习 存储 算法
【LeetCode 热题100】347:前 K 个高频元素(详细解析)(Go语言版)
这篇文章详细解析了力扣热题 347——前 K 个高频元素的三种解法:哈希表+小顶堆、哈希表+快速排序和哈希表+桶排序。每种方法都附有清晰的思路讲解和 Go 语言代码实现。小顶堆方法时间复杂度为 O(n log k),适合处理大规模数据;快速排序方法时间复杂度为 O(n log n),适用于数据量较小的场景;桶排序方法在特定条件下能达到线性时间复杂度 O(n)。文章通过对比分析,帮助读者根据实际需求选择最优解法,并提供了完整的代码示例,是一篇非常实用的算法学习资料。
501 90
|
存储 算法 Java
解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用
在Java中,Set接口以其独特的“无重复”特性脱颖而出。本文通过解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用。
242 3
【LeetCode 27】347.前k个高频元素
【LeetCode 27】347.前k个高频元素
137 0
|
算法
Leetcode 初级算法 --- 数组篇
Leetcode 初级算法 --- 数组篇
148 0
|
存储 算法 Java
leetcode算法题-有效的括号(简单)
【11月更文挑战第5天】本文介绍了 LeetCode 上“有效的括号”这道题的解法。题目要求判断一个只包含括号字符的字符串是否有效。有效字符串需满足左括号必须用相同类型的右括号闭合,并且左括号必须以正确的顺序闭合。解题思路是使用栈数据结构,遍历字符串时将左括号压入栈中,遇到右括号时检查栈顶元素是否匹配。最后根据栈是否为空来判断字符串中的括号是否有效。示例代码包括 Python 和 Java 版本。
292 4
|
存储 算法 Java
Set接口及其主要实现类(如HashSet、TreeSet)如何通过特定数据结构和算法确保元素唯一性
Java Set因其“无重复”特性在集合框架中独树一帜。本文解析了Set接口及其主要实现类(如HashSet、TreeSet)如何通过特定数据结构和算法确保元素唯一性,并提供了最佳实践建议,包括选择合适的Set实现类和正确实现自定义对象的hashCode()与equals()方法。
307 4
|
算法
每日一道算法题(Leetcode 20)
每日一道算法题(Leetcode 20)
179 2
【LeetCode 06】203.移除链表元素
【LeetCode 06】203.移除链表元素
126 0

热门文章

最新文章