【Swift 算法实战】判断数组中是否存在重复元素


大家好,我是 展菲,目前在上市企业从事人工智能项目研发管理工作,平时热衷于分享各种编程领域的软硬技能知识以及前沿技术,包括iOS、前端、Harmony OS、Java、Python等方向。在移动端开发、鸿蒙开发、物联网、嵌入式、云原生、开源等领域有深厚造诣。
图书作者:《ESP32-C3 物联网工程开发实战》
图书作者:《SwiftUI 入门,进阶与实战》
超级个体:COC上海社区主理人
特约讲师:大学讲师,谷歌亚马逊分享嘉宾
科技博主:极星会首批签约作者
文章目录
- 摘要
- 描述
- 题解答案
- 题解代码分析
- 思路
- Swift 代码实现
- 示例测试及结果
- 示例 1:
- 示例 2:
- 示例 3:
- 时间复杂度与空间复杂度
- 总结
- 参考资料
摘要
在这篇文章中,我们将实现一个简单的算法来判断一个整数数组中是否包含至少一个重复元素。根据题目要求,如果数组中任意元素出现至少两次,返回 true,否则返回 false。我们将介绍几种常见的解法,并重点关注效率和性能优化。

描述
给你一个整数数组 nums 。如果任一值在数组中出现 至少两次 ,返回 true ;如果数组中每个元素互不相同,返回 false 。
示例 1:
输入: nums = [1,2,3,1]
输出: true
解释:
元素 1 在下标 0 和 3 出现。
示例 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

题解答案
为了判断数组中是否存在重复元素,我们可以使用以下几种方法:
-
使用
Set(集合)来判断
由于集合中的元素是唯一的,我们可以利用这一点来快速判断是否有重复的元素。如果在插入元素时发现该元素已经存在于集合中,则表示有重复元素。 -
使用暴力法
通过嵌套循环遍历每对元素,逐一比较,判断是否有重复值。尽管实现简单,但性能较差,尤其是在大数组时效率低下。 -
排序法
将数组排序后,只需遍历一次数组,检查相邻元素是否相等。排序的时间复杂度为O(n log n),在一定情况下可能比Set更高效。
在这里,我们重点介绍第一种方法,使用 Swift 中的 Set 来判断是否有重复元素。
题解代码分析
思路
- 遍历数组,尝试将每个元素加入
Set中。 - 如果元素已经存在于
Set中,返回true,表示存在重复元素。 - 如果遍历完成后没有发现重复元素,返回
false。
Swift 代码实现
func containsDuplicate(_ nums: [Int]) -> Bool {var seen = Set<Int>()for num in nums {if seen.contains(num) {return true // 找到重复元素}seen.insert(num) // 将当前元素插入 Set}return false // 没有重复元素
}
示例测试及结果
示例 1:
let nums1 = [1, 2, 3, 1]
print(containsDuplicate(nums1)) // 输出 true
示例 2:
let nums2 = [1, 2, 3, 4]
print(containsDuplicate(nums2)) // 输出 false
示例 3:
let nums3 = [1, 1, 1, 3, 3, 4, 3, 2, 4, 2]
print(containsDuplicate(nums3)) // 输出 true
时间复杂度与空间复杂度
-
时间复杂度:
O(n)
遍历数组一次,每次操作Set的插入和查找都是常数时间复杂度O(1)。 -
空间复杂度:
O(n)
最坏情况下,Set会存储n个元素,因此空间复杂度是O(n)。
总结
本文介绍了如何高效判断数组中是否有重复元素。我们使用了 Set 数据结构,利用其元素唯一的特性,可以在 O(n) 的时间复杂度内完成判断。相比暴力法和排序法,使用 Set 提供了一种简洁且高效的解决方案。
这种方法不仅适用于整数数组,还能处理其他类型的数据,具有广泛的应用场景。
未来如果有更复杂的需求(如需要额外的信息,或者需要考虑其他数据结构的优化),可以考虑使用哈希表或其他数据结构,进一步提升算法的性能和可扩展性。
参考资料
- Swift 官方文档
- LeetCode 题目解答:Contains Duplicate
相关文章:
【Swift 算法实战】判断数组中是否存在重复元素
网罗开发 (小红书、快手、视频号同名) 大家好,我是 展菲,目前在上市企业从事人工智能项目研发管理工作,平时热衷于分享各种编程领域的软硬技能知识以及前沿技术,包括iOS、前端、Harmony OS、Java、Python等…...
Spock框架:让单元测试更优雅的高效武器
📖 前言:为什么选择Spock? 在软件开发领域,单元测试是保证代码质量的基石。但传统的JUnit/TestNG测试框架在面对复杂测试场景时,往往会显得力不从心。Spock框架作为新一代测试框架的佼佼者,以其独特的BDD&…...
【前端基础】Day 4 CSS盒子模型
目录 1. 盒子模型 1.1 盒子模型布局 1.2 盒子模型组成 1.3 边框 1.4 表格细线边框 1.5 边框会影响盒子实际大小 1.6 内边距 1.7 外边距 1.8 外边距合并 1.9 清除内外边距 2. PS基本操作 3. 综合案例 3.1 案例1 3.2 案例2-快报模块 4. 圆角边框 5. 盒子阴影 6…...
补题蓝桥杯14届JavaB组第4题
算法:动态规划 需要两个一维数组来进行dp 一个用来记录到当前位置的最短时间,另一个用来记录到达当前位置传送门的最短时间 到达传送门的时间需要进行判断,如果上一次传送到达传送门,需要判断上一次传送到这的位置在当前传送门…...
kotlin的函数标准库使用
摘要说明 函数标准库常用的有: 1、apply: apply函数作为一个配置函数,可以传入一个接收者,然后调用一系列函数来配置它以方便使用,如果提供lambda给apply函数执行,它会返回配置好的接收者 使用介绍&#x…...
Visual Studio Code 跨平台安装与配置指南(附官方下载链接)
一、软件定位与核心功能 Visual Studio Code(简称VS Code)是微软开发的开源跨平台代码编辑器,支持超过50种编程语言的智能补全、调试和版本控制功能。2025版本新增AI辅助编程模块,可自动生成单元测试代码和API文档注释。 二、下载…...
STM32学习【4】ARM汇编(够用)
目录 ARM汇编语言基础写在前面 1. ARM汇编的分类2. 关于指令集指令集切换Thumb2指令集统一汇编语言(UAL)常用汇编指令 3. 汇编格式立即数与伪指令 4. 操作内存的汇编指令LDR:从内存加载数据到CPU寄存器STR:将数据从寄存器存储到内…...
Linux驱动开发实战(一):LED控制驱动详解
Linux驱动开发野火实战(一):LED控制驱动详解 文章目录 Linux驱动开发野火实战(一):LED控制驱动详解引言一、基础知识1.1 什么是字符设备驱动1.2 重要的数据结构read 函数write 函数open 函数release 函数 二…...
windows下安装pyenv+virtualenv+virtualenvwrapper
1、下载pyenv 进入git官网,打包下载zip到本地 2、解压到安装目录 解压下载好的pyenv-win-master.zip到自己的安装目录,如D:\Program Files 3、配置环境变量 右击桌面 此电脑 --> 属性 --> 高端系统设置 --> 环境变量 --> 新建系统变量…...
Cherno 游戏引擎笔记(91~111)
好久不见! 个人库的地址:(GitHub - JJJJJJJustin/Nut: The game_engine which learned from Cherno),可以看到我及时更新的结果。 -------------------------------Saving & Loading scene-----------------------…...
0x02 js、Vue、Ajax
文章目录 js核心概念js脚本引入html的方式基础语法事件监听 Vuevue简介v-forv-bindv-if&v-showv-model&v-on Ajax js 核心概念 JavaScript:是一门跨平台、面向对象的脚本语言,用来控制网页行为实现交互效果,由ECMAScript、BOM、DOM…...
Windows 11【1001问】删除Win11左下角小组件的6种方法
在Windows 11中,左下角的小组件功能虽然提供了天气、新闻等实用信息,但对于一些用户来说可能显得多余或干扰视线。因此,微软提供了多种方式让用户能够自定义是否显示这些小组件。以下是 6 种常见的设置方法来隐藏或关闭Windows 11左下角的小组…...
【动手学深度学习】基于Python动手实现线性神经网络
深度学习入门:基于Python动手实现线性回归 1,走进深度学习2,配置说明3,线性神经网络4,线性回归从0开始实现4.1,导入相关库4.2,生成数据4.3,读取数据集4.4,初始化模型参数…...
leetcode 912. 排序数组
912. 排序数组 912. 排序数组 题目 给你一个整数数组 nums,请你将该数组升序排列。 你必须在 不使用任何内置函数 的情况下解决问题,时间复杂度为 O(nlog(n)),并且空间复杂度尽可能小。 示例 1: 输入:nums [5,2,3,1…...
【芯片设计】NPU芯片前端设计工程师面试记录·20250227
应聘公司 某NPU/CPU方向芯片设计公司。 小声吐槽两句,前面我问了hr需不需要带简历,hr不用公司给打好了,然后我就没带空手去的。结果hr小姐姐去开会了,手机静音( Ĭ ^ Ĭ )面试官、我、另外的hr小姐姐都联系不上,结果就变成了两个面试官和我一共三个人在会议室里一人拿出…...
BUU40 [CSCCTF 2019 Qual]FlaskLight1【SSTI】
模板: {{.__class__.__base__.__subclasses__()[80].__init__.__globals__[__builtins__].eval("__import__(os).popen(type flag.txt).read()")}} 是个空字符串,.__class__代表这个空字符串的类是什么(这里是单引号双引号都行&a…...
WiFi IEEE 802.11协议精读:IEEE 802.11-2007,6,MAC service definition MAC服务定义
继续精读IEEE 802.11-2007 6,MAC service definition MAC服务定义 6.1 MAC服务概述 6.1.1 数据服务 此服务为对等逻辑链路控制(LLC)实体提供交换MAC服务数据单元(MSDU)的能力。为支持此服务,本地媒体访…...
2025学年安徽省职业院校技能大赛 “信息安全管理与评估”赛项 比赛样题任务书
2024-2025 学年广东省职业院校技能大赛 “信息安全管理与评估”赛项 技能测试试卷(五) 第一部分:网络平台搭建与设备安全防护任务书第二部分:网络安全事件响应、数字取证调查、应用程序安全任务书任务1 :内存取证&…...
VAE变分自编码器的初步理解
VAE的结构和原理 VAE由两部分组成: 编码器(Encoder): 编码器负责将输入数据(例如图像)压缩成一个潜在空间(latent space)的表示。这个潜在空间不是一个固定的值,而是一个…...
2025 最新版鸿蒙 HarmonyOS 开发工具安装使用指南
为保证 DevEco Studio 正常运行,建议电脑配置满足如下要求: Windows 系统 操作系统:Windows10 64 位、Windows11 64 位内存:16GB 及以上硬盘:100GB 及以上分辨率:1280*800 像素及以上 macOS 系统 操作系统…...
AMD Ryzen SDT调试工具:释放处理器潜能的终极硬件控制方案
AMD Ryzen SDT调试工具:释放处理器潜能的终极硬件控制方案 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: https:…...
从Java转行大模型应用,Dify 本地部署和可视化智能体创建全流程(低代码 + 脚本)
Dify 是开源低代码 AI 应用开发平台,支持Docker 一键本地私有化部署,通过可视化拖拽即可创建智能体,无需复杂编码,还可通过脚本自动化部署与智能体配置。以下是完整实操方案:一、本地部署(Docker Compose&a…...
数据可视化如何落地?一篇讲清楚数据可视化应用
其实大部分人一开始学数据可视化,最容易卡在一个地方,就是学了不少图表类型,真到工作里却不知道该怎么用。经常会问:这张图到底该怎么做,这些数据到底该怎么展示,这样展示是不是对业务真有帮助?…...
Krita-Vision-Tools:数字艺术家的AI助手,一键智能选区革命
Krita-Vision-Tools:数字艺术家的AI助手,一键智能选区革命 【免费下载链接】krita-vision-tools Krita plugin which adds selection tools to mask objects with a single click, or by drawing a bounding box. 项目地址: https://gitcode.com/gh_mi…...
Ansys静力学分析中EPTO数据缺失与PRNSOL命令失效的解决方案
1. 遇到EPTO数据不可用和PRNSOL命令失效怎么办? 最近在用Ansys做静力学分析时,遇到了一个让人头疼的问题:当我想要查看应变结果列表时,系统提示"The requested EPTO data is not available. The PRNSOL command is ignored&q…...
3个简单步骤快速解决Jellyfin元数据插件MetaShark安装与使用问题
3个简单步骤快速解决Jellyfin元数据插件MetaShark安装与使用问题 【免费下载链接】jellyfin-plugin-metashark jellyfin电影元数据插件 项目地址: https://gitcode.com/gh_mirrors/je/jellyfin-plugin-metashark Jellyfin电影元数据插件MetaShark是一款专为Jellyfin媒体…...
别再手动回微信了!用Python+WxAuto给电脑微信装个AI助理(支持ChatGPT/DeepSeek)
打造智能微信助手:PythonWxAuto实现24小时AI自动回复系统 微信已经成为现代人工作和生活中不可或缺的通讯工具,但对于忙碌的开发者、电商运营者或自由职业者来说,频繁的消息回复常常成为效率杀手。想象一下这样的场景:当你正在专…...
3步掌握RePKG:从Wallpaper Engine资源包到可编辑素材
3步掌握RePKG:从Wallpaper Engine资源包到可编辑素材 【免费下载链接】repkg Wallpaper engine PKG extractor/TEX to image converter 项目地址: https://gitcode.com/gh_mirrors/re/repkg Wallpaper Engine资源包逆向解析工具RePKG,专为提取壁纸…...
Java与C++:7大核心差异全解析
好的,Java 和 C 都是广泛使用的面向对象编程语言,但它们在设计哲学、特性和应用场景上存在显著区别。以下是它们的主要差异:1. 内存管理C:支持手动内存管理(通过 new/delete 操作符)。程序员需自行分配和释…...
NLP-StructBERT赋能智能写作助手:查重与素材推荐一体化方案
NLP-StructBERT赋能智能写作助手:查重与素材推荐一体化方案 每次写完稿子,你是不是也有这样的烦恼?一边担心自己是不是无意中“借鉴”了别人的观点,一边又得花大量时间去翻找资料、寻找案例来支撑自己的论点。对于媒体人和学术研…...
