posts - 26,comments - 0,views - 20658
判断数组是否存在重复元素
/*

给定一个整数数组,判断是否存在重复元素。
如果存在一值在数组中出现至少两次,函数返回 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
*/
复制代码
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;

public class RepeatElements {
    public static void main(String[] args) {
       int[] nums={3,1,2,6,8,5,4,6};
        long start = System.currentTimeMillis();
        boolean b = containsDuplicate(nums);

        long end = System.currentTimeMillis();
        System.out.println("解"+b+"---时间:"+(end-start)+"ms");
    }
    public static boolean containsDuplicate(int[] nums) {

        Map<Integer,Integer> map=new HashMap<Integer,Integer>();
        for (int i = 0; i < nums.length; i++) {
            if (map.containsKey(nums[i])){
                return true;
            }
            map.put(nums[i],nums[i]);
        }
        return false;

    }
    public static boolean containsDuplicate2(int[] nums) {
        Set<Integer> set = new HashSet<Integer>();
        for (int x : nums) {
            if (!set.add(x)) {
                return true;
            }
        }
        return false;
    }
}
复制代码

方法一:这个不难理解 每次循环都将数组元素存放到map里面,然后通过 map.containsKey()函数判断map里面是否存在与下标为i的元素相等的key。如果存在那么我们返回true,退出循环。如果直到循环完成都没有重复的元素那么就返回false。

方法二:要知道hashset是不允许添加重复元素的,那么我们每次都往HashSet里面添加元素,如果添加函数返回false即为添加失败,说明set集合中已经存在该元素,那么我们就返回false。

两种方法对比肯定方法二执行的更快一些,只做了添加操作,方法一不但执行了添加操作还有一个查找的操作。

这样问题就解决了,如果你们有更好的方法欢迎下方评论

 

posted on   简易代码  阅读(1581)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示