算法题 在长度 2N 的数组中找出重复 N 次的元素

在长度 2N 的数组中找出重复 N 次的元素

问题描述

给定一个整数数组nums,其长度为2N。数组中恰好有一个元素重复了N次,其余N个元素都是唯一的。请返回重复了N次的元素。

约束条件

  • 2 <= nums.length <= 10000
  • nums.length是偶数
  • 0 <= nums[i] < 10000
  • 数组中恰好有一个元素重复了N

示例

输入: [1,2,3,3] 输出: 3 解释: 数组长度为4 (2N=4, N=2),元素3重复了2次。 输入: [2,1,2,5,3,2] 输出: 2 解释: 数组长度为6 (2N=6, N=3),元素2重复了3次。 输入: [5,1,5,2,5,3,5,4] 输出: 5 解释: 数组长度为8 (2N=8, N=4),元素5重复了4次。

算法思路

方法一:哈希表计数

使用哈希表统计每个元素的出现次数,找到出现次数为N的元素。

方法二:数学

由于数组长度为2N,有一个元素出现N次,其余N个元素各出现 1 次。重复元素占据了数组的一半。

代码实现

方法一:哈希表计数

importjava.util.*;classSolution{/** * 使用哈希表统计元素频次,找到重复N次的元素 * * @param nums 长度为2N的整数数组 * @return 重复了N次的元素 */publicintrepeatedNTimes(int[]nums){Map<Integer,Integer>count=newHashMap<>();intn=nums.length/2;// 重复次数for(intnum:nums){count.put(num,count.getOrDefault(num,0)+1);// 一旦发现某个元素出现次数达到n,立即返回if(count.get(num)==n){returnnum;}}return-1;}}

方法二:间隔

classSolution{/** * 重复元素间隔不超过2 * * @param nums 长度为2N的整数数组 * @return 重复了N次的元素 */publicintrepeatedNTimes(int[]nums){// 检查所有间隔为1的相邻元素对for(inti=0;i<nums.length-1;i++){if(nums[i]==nums[i+1]){returnnums[i];}}// 检查所有间隔为2的元素对for(inti=0;i<nums.length-2;i++){if(nums[i]==nums[i+2]){returnnums[i];}}// 检查所有间隔为3的元素对(只在小数组中需要)for(inti=0;i<nums.length-3;i++){if(nums[i]==nums[i+3]){returnnums[i];}}// 对于长度为4的特殊情况,检查首尾元素returnnums[0];}}

算法分析

方法一:哈希表计数

  • 时间复杂度:O(N)
    • 最坏情况下需要遍历整个数组
    • 平均情况下可能提前找到答案
  • 空间复杂度:O(N)
    • 哈希表最多存储 N+1 个不同元素

方法二:间隔

  • 时间复杂度:O(N)
    • 只需要三次线性扫描
  • 空间复杂度:O(1)
    • 只使用常数额外空间

算法过程

输入[5,1,5,2,5,3,5,4](N=4):

方法一:

  1. 统计频次:5→1, 1→1, 5→2, 2→1, 5→3, 3→1, 5→4
  2. 当 5 的计数达到 4 时,立即返回 5

方法二:

  1. 检查相邻元素:5≠1, 1≠5, 5≠2, 2≠5, 5≠3, 3≠5, 5≠4 → 无匹配
  2. 检查间隔为2的元素:5==5(索引0和2)→ 返回 5

测试用例

publicclassTestRepeatedNTimes{publicstaticvoidmain(String[]args){Solutionsolution=newSolution();// 测试用例1:基本示例int[]nums1={1,2,3,3};System.out.println("Test 1: "+solution.repeatedNTimes(nums1));// 3// 测试用例2:N=3的情况int[]nums2={2,1,2,5,3,2};System.out.println("Test 2: "+solution.repeatedNTimes(nums2));// 2// 测试用例3:N=4的情况int[]nums3={5,1,5,2,5,3,5,4};System.out.println("Test 3: "+solution.repeatedNTimes(nums3));// 5// 测试用例4:相邻重复int[]nums4={1,1,2,3};System.out.println("Test 4: "+solution.repeatedNTimes(nums4));// 1// 测试用例5:间隔为2的重复int[]nums5={1,2,1,3};System.out.println("Test 5: "+solution.repeatedNTimes(nums5));// 1// 测试用例6:最大规模int[]nums6=newint[10000];for(inti=0;i<5000;i++){nums6[i]=9999;// 重复5000次}for(inti=5000;i<10000;i++){nums6[i]=i-5000;// 其他唯一元素}System.out.println("Test 6: "+solution.repeatedNTimes(nums6));// 9999}}

关键点

  1. 问题

    • 重复元素占数组一半
  2. 间隔

    • 重复元素无法完全均匀分散
    • 必然存在两个重复元素的距离不超过 2

常见问题

  1. 为什么方法二中只需要检查间隔1、2、3?
    • 通过鸽巢原理可以证明,在 2N 长度的数组中放置 N 个相同元素,必然存在两个相同元素的距离 ≤ 3。
    • 对于 N≥3,距离 ≤ 2 就足够了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1191756.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

为什么Qwen3-1.7B调用失败?LangChain接入避坑指南

为什么Qwen3-1.7B调用失败&#xff1f;LangChain接入避坑指南 你是不是也遇到了这样的问题&#xff1a;明明按照文档配置好了环境&#xff0c;代码看着也没错&#xff0c;可一运行 chat_model.invoke("你是谁&#xff1f;") 就报错&#xff0c;Qwen3-1.7B就是调不通…

有全局感受野的傅里叶卷积块用于MRI重建/文献速递-基于人工智能的医学影像技术

2026.1.20本文提出一种用于MRI重建的傅里叶卷积块&#xff08;FCB&#xff09;&#xff0c;通过将空间域卷积转换为频域操作&#xff0c;实现了全局感受野和低计算复杂度&#xff0c;并在多种CNN架构上展现出优于现有SOTA方法和Vision Transformer的重建性能&#xff0c;有效抑…

Qwen3Guard-Gen-WEB数据隔离:私有化部署实战

Qwen3Guard-Gen-WEB数据隔离&#xff1a;私有化部署实战 在AI应用快速落地的今天&#xff0c;内容安全审核已成为不可忽视的关键环节。尤其在企业级场景中&#xff0c;如何确保用户输入和模型响应不触碰合规红线&#xff0c;同时保障数据不出内网、实现彻底的数据隔离&#xf…

算法题 最大宽度坡

最大宽度坡 问题描述 给定一个整数数组 nums&#xff0c;定义一个坡为元组 (i, j)&#xff0c;其中 i < j 且 nums[i] < nums[j]。坡的宽度为 j - i。 请返回数组中最大宽度坡的宽度。如果没有坡&#xff0c;返回 0。 示例&#xff1a; 输入: [6,0,8,2,1,5] 输出: 4 解释…

unet image Face Fusion跨域问题解决?CORS配置正确姿势

unet image Face Fusion跨域问题解决&#xff1f;CORS配置正确姿势 1. 背景与问题引入 在部署基于 unet image Face Fusion 的人脸融合 WebUI 应用时&#xff0c;很多开发者会遇到一个看似简单却极具迷惑性的问题&#xff1a;前端页面能正常加载&#xff0c;但图片上传或融合…

江苏硕晟LIMS pro3.0:引领实验室信息管理新高度

公司介绍&#xff1a;专业铸就行业标杆江苏硕晟科学器材有限公司成立于2018年&#xff0c;是一家专注于实验室数字化转型的科技型中小企业。公司以"软件 硬件 服务 咨询"为核心业务模式&#xff0c;为各行业实验室提供一站式信息化解决方案。凭借在实验室信息管理…

Java Web mvc高校办公室行政事务管理系统系统源码-SpringBoot2+Vue3+MyBatis-Plus+MySQL8.0【含文档】

&#x1f4a1;实话实说&#xff1a;有自己的项目库存&#xff0c;不需要找别人拿货再加价&#xff0c;所以能给到超低价格。摘要 随着高校规模的不断扩大和行政事务的日益复杂&#xff0c;传统的人工管理模式已难以满足高效、精准的管理需求。高校办公室行政事务管理系统旨在通…

Qwen3-Embedding-0.6B与text-embedding-ada-002对比评测

Qwen3-Embedding-0.6B与text-embedding-ada-002对比评测 1. Qwen3-Embedding-0.6B 模型解析 1.1 核心能力与技术背景 Qwen3 Embedding 模型系列是 Qwen 家族中专为文本嵌入和排序任务打造的最新成员&#xff0c;基于强大的 Qwen3 系列密集基础模型构建。该系列覆盖了从轻量级…

用Qwen3-0.6B做的第一个AI项目——新闻分类器上线

用Qwen3-0.6B做的第一个AI项目——新闻分类器上线 1. 项目背景与目标 最近在尝试把大模型真正用起来&#xff0c;而不是停留在“调API、跑demo”的阶段。于是决定动手做一个完整的AI小项目&#xff1a;基于Qwen3-0.6B搭建一个新闻自动分类系统&#xff0c;并把它部署上线&…

Z-Image-Turbo支持哪些格式?PNG转换技巧分享

Z-Image-Turbo支持哪些格式&#xff1f;PNG转换技巧分享 1. Z-Image-Turbo图像生成与输出格式详解 阿里通义Z-Image-Turbo WebUI图像快速生成模型&#xff0c;由社区开发者“科哥”基于DiffSynth Studio框架进行二次开发构建&#xff0c;是一款专注于高效、高质量AI图像生成的…

SpringBoot+Vue 在线问卷调查系统管理平台源码【适合毕设/课设/学习】Java+MySQL

&#x1f4a1;实话实说&#xff1a;有自己的项目库存&#xff0c;不需要找别人拿货再加价&#xff0c;所以能给到超低价格。摘要 随着信息化时代的快速发展&#xff0c;问卷调查作为一种高效的数据收集方式&#xff0c;在学术研究、市场调研和社会分析等领域发挥着重要作用。传…

fft npainting lama日志轮转配置:避免磁盘空间耗尽最佳实践

fft npainting lama日志轮转配置&#xff1a;避免磁盘空间耗尽最佳实践 1. 引言&#xff1a;为什么日志管理至关重要 你有没有遇到过这样的情况&#xff1a;系统运行得好好的&#xff0c;突然某天发现WebUI打不开了&#xff0c;SSH连不上&#xff0c;或者提示“磁盘已满”&am…

Qwen3-1.7B vs Phi-3-mini:端侧部署可行性对比评测

Qwen3-1.7B vs Phi-3-mini&#xff1a;端侧部署可行性对比评测 1. 模型背景与核心定位 1.1 Qwen3-1.7B&#xff1a;轻量级通义千问的端侧潜力 Qwen3&#xff08;千问3&#xff09;是阿里巴巴集团于2025年4月29日开源的新一代通义千问大语言模型系列&#xff0c;涵盖6款密集模…

Qwen3-1.7B跨境电商应用:多语言商品描述生成

Qwen3-1.7B跨境电商应用&#xff1a;多语言商品描述生成 1. Qwen3-1.7B 模型简介 Qwen3&#xff08;千问3&#xff09;是阿里巴巴集团于2025年4月29日开源的新一代通义千问大语言模型系列&#xff0c;涵盖6款密集模型和2款混合专家&#xff08;MoE&#xff09;架构模型&#…

Qwen-Image-2512-ComfyUI文旅宣传应用:景区海报自动生成系统

Qwen-Image-2512-ComfyUI文旅宣传应用&#xff1a;景区海报自动生成系统 1. 让景区宣传更高效&#xff1a;AI如何改变文旅内容创作 你有没有遇到过这样的情况&#xff1f;旅游旺季临近&#xff0c;宣传物料却还在等设计师加班出图&#xff1b;一个景区有十几个打卡点&#xf…

计算机毕业设计springboot大学生兼职信息管理系统 基于SpringBoot的高校学生兼职岗位智能撮合平台 面向校园的兼职资源一站式管理与匹配系统

计算机毕业设计springboot大学生兼职信息管理系统&#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。当“副业刚需”成为大学生群体的关键词&#xff0c;信息分散、真假难辨、流程繁…

Arbess项目实战 - 基于GitHub实现Java项目构建并自动化Docker部署

Arbess 是一款国产开源免费的 CI/CD 工具&#xff0c;支持免费自动化部署&#xff0c;一键安装零配置。本文将详细介绍如何安装并使用ArbessGitHub实现Docker项目自动化构建部署 1、GitHub 配置 本章节将介绍如何创建GitHub个人访问令牌&#xff0c;提供给Arbess克隆源码。 …

Python系列Bug修复|如何解决 pip install 安装报错 ModuleNotFoundError: No module named ‘catboost’ 问题

摘要 你在使用pip install安装catboost库&#xff0c;或运行Python代码时遇到ModuleNotFoundError: No module named catboost报错&#xff0c;该问题核心诱因是pip与Python环境错位&#xff08;安装路径不匹配&#xff0c;占40%&#xff09; 网络/源问题导致安装不完整&…

计算机毕业设计springboot大学生健康管理系统 基于SpringBoot的高校学生身心健康追踪与干预平台 校园健康云:面向大学生的智能健康档案与风险预警系统

计算机毕业设计springboot大学生健康管理系统&#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。“脆皮大学生”不是梗&#xff0c;是警报。体测前夜突击锻炼、熬夜刷剧到三点、心理…

Python系列Bug修复|如何解决 pip install 安装报错 ModuleNotFoundError: No module named ‘lightgbm’ 问题

摘要 你在使用pip install安装lightgbm库&#xff0c;或运行Python代码时遇到ModuleNotFoundError: No module named lightgbm报错&#xff0c;该问题核心诱因是pip与Python环境错位&#xff08;安装路径不匹配&#xff0c;占40%&#xff09; 网络/源问题导致安装不完整&…