当前位置: 首页 > news >正文

LeetCode - #182 Swift 实现找出重复的电子邮件

在这里插入图片描述
在这里插入图片描述

网罗开发 (小红书、快手、视频号同名)

  大家好,我是 展菲,目前在上市企业从事人工智能项目研发管理工作,平时热衷于分享各种编程领域的软硬技能知识以及前沿技术,包括iOS、前端、Harmony OS、Java、Python等方向。在移动端开发、鸿蒙开发、物联网、嵌入式、云原生、开源等领域有深厚造诣。

图书作者:《ESP32-C3 物联网工程开发实战》
图书作者:《SwiftUI 入门,进阶与实战》
超级个体:COC上海社区主理人
特约讲师:大学讲师,谷歌亚马逊分享嘉宾
科技博主:极星会首批签约作者

文章目录

    • 摘要
    • 描述
      • 问题背景
      • 输入输出示例
    • SQL 解法
    • Swift 题解代码
    • Swift 题解代码分析
      • SQL 查询逻辑
      • Swift 实现分析
    • 示例测试及结果
      • 测试 1
    • 时间复杂度
      • SQL 查询
    • 空间复杂度
    • 总结

摘要

在现代数据库系统中,管理电子邮件数据的完整性和准确性非常重要。本文以 SQL 和 Swift 的结合为例,演示如何有效地找到数据库中重复的电子邮件记录。我们将提供完整的代码示例和详细的实现分析,助力开发者快速上手解决类似问题。

描述

问题背景

我们需要从表 Person 中找出所有重复的电子邮件。电子邮件列不为空,且保证全部为小写。返回的结果只包含重复的电子邮件,按任意顺序输出。

输入输出示例

输入:

Person 表:

+----+---------+
| id | email   |
+----+---------+
| 1  | a@b.com |
| 2  | c@d.com |
| 3  | a@b.com |
+----+---------+

输出:

+---------+
| Email   |
+---------+
| a@b.com |
+---------+

解释: a@b.com 出现了两次,因此被列为重复的电子邮件。

SQL 解法

我们可以通过分组查询找到重复的电子邮件,并筛选出出现次数大于 1 的记录。

SQL 查询如下:

SELECT email AS Email
FROM Person
GROUP BY email
HAVING COUNT(email) > 1;

说明:

  1. 分组统计:
    • 使用 GROUP BYemail 分组。
    • 每组统计该 email 的出现次数。
  2. 筛选条件:
    • 使用 HAVING COUNT(email) > 1 过滤出重复的电子邮件。

Swift 题解代码

以下是基于 Swift 的完整实现,使用 SQLite 数据库来存储和查询数据:

import SQLite3func findDuplicateEmails(databasePath: String) -> [String] {var db: OpaquePointer?var stmt: OpaquePointer?var results: [String] = []// 打开数据库连接if sqlite3_open(databasePath, &db) == SQLITE_OK {let query = """SELECT email AS EmailFROM PersonGROUP BY emailHAVING COUNT(email) > 1;"""// 准备 SQL 查询if sqlite3_prepare_v2(db, query, -1, &stmt, nil) == SQLITE_OK {// 执行查询并获取结果while sqlite3_step(stmt) == SQLITE_ROW {if let cString = sqlite3_column_text(stmt, 0) {let email = String(cString: cString)results.append(email)}}} else {print("SQL Error: \(String(cString: sqlite3_errmsg(db)))")}// 清理资源sqlite3_finalize(stmt)}sqlite3_close(db)return results
}// 示例测试
let databasePath = "path_to_your_database.sqlite"
let duplicateEmails = findDuplicateEmails(databasePath: databasePath)
print("Duplicate Emails: \(duplicateEmails)")

Swift 题解代码分析

SQL 查询逻辑

  1. GROUP BY 操作:

    • email 列按值分组,统计每个 email 的数量。
  2. HAVING 条件:

    • 使用聚合函数 COUNT(email) 筛选出出现次数大于 1 的 email
  3. 结果返回:

    • 使用 SELECT email 返回符合条件的电子邮件。

Swift 实现分析

  1. 数据库连接:

    • 使用 sqlite3_open 连接 SQLite 数据库。
  2. 查询执行:

    • 调用 sqlite3_prepare_v2 准备 SQL 查询。
    • 使用 sqlite3_step 遍历查询结果,并将每行的 email 提取到数组 results 中。
  3. 结果输出:

    • 返回重复电子邮件的数组。

示例测试及结果

测试 1

数据库内容:

+----+---------+
| id | email   |
+----+---------+
| 1  | a@b.com |
| 2  | c@d.com |
| 3  | a@b.com |
+----+---------+

运行代码:

let duplicateEmails = findDuplicateEmails(databasePath: databasePath)
print("Duplicate Emails: \(duplicateEmails)")

输出结果:

Duplicate Emails: ["a@b.com"]

时间复杂度

SQL 查询

  1. 分组操作:
    • 时间复杂度为 (O(n \log n)),其中 (n) 是 Person 表的记录数。
  2. 过滤条件:
    • 遍历每个分组的复杂度为 (O(k)),其中 (k) 是分组数。

总时间复杂度: (O(n \log n))。

空间复杂度

  1. 查询结果存储:
    • 需要存储重复的电子邮件,空间复杂度为 (O(k)),其中 (k) 是重复电子邮件的数量。

总空间复杂度: (O(k))。

总结

本文提供了一个完整的解决方案,用于找出数据库中重复的电子邮件。通过 SQL 的分组与聚合操作,结合 Swift 的数据库接口实现,我们能够快速、高效地完成任务。此方法不仅适用于电子邮件,还可扩展至其他重复数据的查询需求。在实践中,配合索引优化可以进一步提升性能。

相关文章:

LeetCode - #182 Swift 实现找出重复的电子邮件

网罗开发 (小红书、快手、视频号同名) 大家好,我是 展菲,目前在上市企业从事人工智能项目研发管理工作,平时热衷于分享各种编程领域的软硬技能知识以及前沿技术,包括iOS、前端、Harmony OS、Java、Python等…...

《解锁鸿蒙Next系统人工智能语音助手开发的关键步骤》

在当今数字化时代,鸿蒙Next系统与人工智能的融合为开发者带来了前所未有的机遇,开发一款人工智能语音助手应用更是备受关注。以下是在鸿蒙Next系统上开发人工智能语音助手应用的关键步骤: 环境搭建与权限申请 安装开发工具:首先需…...

【Linux网络编程】数据链路层 | MAC帧 | ARP协议

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站 🌈个人主页: 南桥几晴秋 🌈C专栏: 南桥谈C 🌈C语言专栏: C语言学习系…...

《自动驾驶与机器人中的SLAM技术》ch7:基于 ESKF 的松耦合 LIO 系统

目录 基于 ESKF 的松耦合 LIO 系统 1 坐标系说明 2 松耦合 LIO 系统的运动和观测方程 3 松耦合 LIO 系统的数据准备 3.1 CloudConvert 类 3.2 MessageSync 类 4 松耦合 LIO 系统的主要流程 4.1 IMU 静止初始化 4.2 ESKF 之 运动过程——使用 IMU 预测 4.3 使用 IMU 预测位姿进…...

基于spingbott+html+Thymeleaf的24小时智能服务器监控平台设计与实现

博主介绍:硕士研究生,专注于信息化技术领域开发与管理,会使用java、标准c/c等开发语言,以及毕业项目实战✌ 从事基于java BS架构、CS架构、c/c 编程工作近16年,拥有近12年的管理工作经验,拥有较丰富的技术架…...

全栈面试(一)Basic/微服务

文章目录 项目地址一、Basic InterviewQuestions1. tell me about yourself?2. tell me about a time when you had to solve a complex code problem?3. tell me a situation that you persuade someone at work?4. tell me a about a confict with a teammate and how you…...

python安装完成后可以进行的后续步骤和注意事项

安装Python3完成后,你可以开始使用它进行编程和开发。以下是一些安装完成后可以进行的后续步骤和注意事项: 验证安装 检查Python版本: 打开“终端”应用程序。输入python3 --version,应该显示安装的Python3版本号。 检查pip版本…...

[Qt] 窗口 | 菜单栏MenuBar

目录 QMainWindow 概述 一、菜单栏 1、创建菜单栏 2、在菜单栏中添加菜单 3、创建菜单项 4、在菜单项之间添加分割线 5、添加快捷键 6、添加子菜单 7、添加图标 综合示例 QMainWindow 概述 Qt 窗口是通过 QMainWindow 类来实现的。 QMainWindow 是一个为用户 提供主…...

[读书日志]从零开始学习Chisel 第十三篇:Scala的隐式参数与隐式转换(敏捷硬件开发语言Chisel与数字系统设计)

10. 隐式转换与隐式参数 假设编写了一个向量类MyVector,并且包含一些向量的基本操作。因为向量可以与标量做数乘运算,所以需要一个计算数乘的方法“*”,它应该接收一个类型为基本值类的参数,在向量对象myVec调用该方法时&#xf…...

CMake学习笔记(1)

1. CMake概述 CMake 是一个项目构建工具,并且是跨平台的。关于项目构建我们所熟知的还有Makefile(通过 make 命令进行项目的构建),大多是IDE软件都集成了make,比如:VS 的 nmake、linux 下的 GNU make、Qt …...

cursor+deepseek构建自己的AI编程助手

文章目录 准备工作在Cursor中添加deepseek 准备工作 下载安装Cursor (默认安装在C盘) 注册deepseek获取API key 在Cursor中添加deepseek 1、打开cursor,选择设置 选择Model,添加deepseek-chat 注意这里去掉其他的勾选项&…...

Kotlin实现DataBinding结合ViewModel的时候,提示找不到Unresolved reference: BR解决方案

在用Kotlin语言实现DataBinding结合ViewModel的代码的时候,如下所示: class UserModel(private val userName: String, private val userAge: Int) : BaseObservable() {get:Bindablevar name: String userNameset (value) {field valuenotifyPropert…...

java项目启动时,执行某方法

1. J2EE项目 在Servlet类中重写init()方法,这个方法会在Servlet实例化时调用,即项目启动时调用。 import javax.servlet.ServletException; import javax.servlet.http.HttpServlet;public class MyServlet extends HttpServlet {Overridepublic void …...

详解如何自定义 Android Dex VMP 保护壳

版权归作者所有,如有转发,请注明文章出处:https://cyrus-studio.github.io/blog/ 前言 Android Dex VMP(Virtual Machine Protection,虚拟机保护)壳是一种常见的应用保护技术,主要用于保护 And…...

Grails应用http.server.requests指标数据采集问题排查及解决

问题 遇到的问题:同一个应用,Spring Boot(Java)和Grails(Groovy)混合编程,常规的Spring Controller,可通过Micromete Pushgateway, 采集到http.server.requests指标数据,注意下面的指标名称是点号&#…...

开源临床试验软件OpenClinica的安装

本文是为帮网友 A萤火虫 解决安装问题做的记录; 简介 什么是 OpenClinica ? OpenClinica 是世界上第一个商业开源临床试验软件,主要用于电子数据捕获(EDC)和临床数据管理(CDM)。它的设计旨在优…...

网络安全 | 网络安全法规:GDPR、CCPA与中国网络安全法

网络安全 | 网络安全法规:GDPR、CCPA与中国网络安全法 一、前言二、欧盟《通用数据保护条例》(GDPR)2.1 背景2.2 主要内容2.3 特点2.4 实施效果与影响 三、美国《加利福尼亚州消费者隐私法案》(CCPA)3.1 背景3.2 主要内…...

深入学习 Python 爬虫:从基础到实战

深入学习 Python 爬虫:从基础到实战 前言 Python 爬虫是一个强大的工具,可以帮助你从互联网上抓取各种数据。无论你是数据分析师、机器学习工程师,还是对网络数据感兴趣的开发者,爬虫都是一个非常实用的技能。在本文中&#xff…...

element plus 使用 upload 组件达到上传数量限制时隐藏上传按钮

最近在重构项目,使用了 element plus UI框架,有个功能是实现图片上传,且限制只能上传一张图片,结果,发现,可以限制只上传一张图片,但是上传按钮还在,如图: 解决办法&…...

音频DSP的发展历史

音频数字信号处理(DSP)的发展历史是电子技术、计算机科学和音频工程共同进步的结果。这个领域的进展不仅改变了音乐制作、音频后期制作和通信的方式,也影响了音频设备的设计和功能。以下是对音频DSP发展历史的概述: 早期概念和理论…...

C语言断言函数详解与最佳实践

1. C语言断言函数基础解析断言(assert)是C语言中一个简单但极其强大的调试工具,它本质上是一个宏而非函数。当我在2008年第一次接触嵌入式开发时,我的导师就强调:"断言是你最好的调试伙伴,它能帮你快速…...

电驱动系统标定视频精讲教程:4.5小时全解析,含文档重难点解析

电驱动系统标定 视频 精讲教程(含文档),培训时长4.5小时。 电驱动重难点解析文档。深夜的实验室里示波器曲线还在跳动,我盯着屏幕上那个0.3秒的扭矩响应延迟,咖啡杯在控制台边沿留下深褐色的印记。电驱动标定工程师最…...

DevOps 实践与自动化:从开发到运维的无缝衔接

DevOps 实践与自动化:从开发到运维的无缝衔接 前言 作为一个在数据深渊里捞了十几年 Bug 的女码农,我深知 DevOps 在现代软件开发中的重要性。DevOps 不仅是一种技术实践,更是一种文化和思维方式,它强调开发和运维团队的紧密协作&…...

嵌入式实时系统AnOs的分时分区架构解析

1. AnOs:嵌入式分时分区实时系统解析作为一名在嵌入式领域摸爬滚打多年的工程师,第一次看到AnOs这个项目时眼前一亮。它让我想起了十年前在军工项目中调试VxWorks 653的经历——那种严格的分区保护和实时调度机制,在工业控制、航空航天等高安…...

Go语言的命令行工具:从flag到cobra

Go语言的命令行工具:从flag到cobra 1. 引言 命令行工具是软件开发中不可或缺的一部分,它们可以帮助我们自动化任务、管理系统、处理数据等。Go语言以其简洁的语法和强大的标准库,成为了开发命令行工具的理想选择。从基础的flag包到高级的co…...

C# OPC连接方式实现上位机与PLC的通用通讯源码分享

C#连接OPC C#上位机链接PLC程序源码 1.该程序是通讯方式是CSharp通过OPC方式连接PLC,用这种方式连PLC不用考虑什么种类PLC,只要OPC服务器里有的PLC都可以连。 2.该资料包含程序,还有一些学习资料。C# 与 OPC 自动化接口深度实践&#xff1a…...

豆包写小说软件2025推荐,专业写作助力灵感迸发

豆包写小说软件2025推荐,专业写作助力灵感迸发在当今数字化时代,写小说成为了许多人表达自我、实现创作梦想的途径。然而,对于众多写作者来说,寻找一款专业且实用的写小说软件并非易事。据《2025中国写作软件行业白皮书》显示&…...

e1547:让社区浏览体验回归纯粹的定制化浏览器

e1547:让社区浏览体验回归纯粹的定制化浏览器 【免费下载链接】e1547 A sophisticated e621 browser 项目地址: https://gitcode.com/gh_mirrors/e1/e1547 问题引入:当浏览变成筛选的艺术 在内容爆炸的时代,每位用户都渴望看到真正感…...

可变形卷积(Deformable Convolution)原理与在YOLOv11中的集成

上周在产线测试YOLOv11的缺陷检测模型,遇到个头疼的问题:同一类金属件,因为冲压模具磨损导致边缘出现轻微形变,模型漏检率突然飙升。常规的卷积核是固定网格采样,对这类几何形变缺乏适应性。调了一整天数据增强&#x…...

掌握Scalaz函子Functor:函数式编程的终极指南

掌握Scalaz函子Functor:函数式编程的终极指南 【免费下载链接】scalaz Principled Functional Programming in Scala 项目地址: https://gitcode.com/gh_mirrors/sc/scalaz Scalaz是一个强大的Scala函数式编程库,而Functor(函子&#…...