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



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

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

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

文章目录

摘要

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

描述

问题背景

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

输入输出示例

输入:

Person 表:

复制代码
+----+---------+
| id | email   |
+----+---------+
| 1  | [email protected] |
| 2  | [email protected] |
| 3  | [email protected] |
+----+---------+

输出:

复制代码
+---------+
| Email   |
+---------+
| [email protected] |
+---------+

解释: [email protected] 出现了两次,因此被列为重复的电子邮件。

SQL 解法

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

SQL 查询如下:

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 数据库来存储和查询数据:

swift 复制代码
import SQLite3

func 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 Email
        FROM Person
        GROUP BY email
        HAVING 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  | [email protected] |
| 2  | [email protected] |
| 3  | [email protected] |
+----+---------+

运行代码:

swift 复制代码
let duplicateEmails = findDuplicateEmails(databasePath: databasePath)
print("Duplicate Emails: \(duplicateEmails)")

输出结果:

复制代码
Duplicate Emails: ["[email protected]"]

时间复杂度

SQL 查询

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

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

空间复杂度

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

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

总结

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

相关推荐
跳跳糖炒酸奶20 分钟前
第四章、Isaacsim在GUI中构建机器人(2):组装一个简单的机器人
人工智能·python·算法·ubuntu·机器人
绵绵细雨中的乡音35 分钟前
动态规划-第六篇
算法·动态规划
程序员黄同学1 小时前
动态规划,如何应用动态规划解决实际问题?
算法·动态规划
march_birds1 小时前
FreeRTOS 与 RT-Thread 事件组对比分析
c语言·单片机·算法·系统架构
斯汤雷2 小时前
Matlab绘图案例,设置图片大小,坐标轴比例为黄金比
数据库·人工智能·算法·matlab·信息可视化
云 无 心 以 出 岫2 小时前
贪心算法QwQ
数据结构·c++·算法·贪心算法
Lexiaoyao202 小时前
SwiftUI 字体系统详解
swiftui·swift
俏布斯2 小时前
算法日常记录
java·算法·leetcode
独好紫罗兰2 小时前
洛谷题单3-P5719 【深基4.例3】分类平均-python-流程图重构
开发语言·python·算法
YungFan2 小时前
Swift 6.1 新特性
swift