判断数组是否存在重复元素
/*
给定一个整数数组,判断是否存在重复元素。
如果存在一值在数组中出现至少两次,函数返回 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。
两种方法对比肯定方法二执行的更快一些,只做了添加操作,方法一不但执行了添加操作还有一个查找的操作。
这样问题就解决了,如果你们有更好的方法欢迎下方评论
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通