08 - 集合set:去重和快速查找

想系统提升编程能力、查看更完整的学习路线,欢迎访问 AI Compass:https://github.com/tingaicompass/AI-Compass

仓库持续更新刷题题解、Python 基础和 AI 实战内容,适合想高效进阶的你。

08 - 集合set:去重和快速查找

学习目标: 掌握集合的创建和应用


💻 代码示例

1. 创建集合

python 复制代码
# 方法1:花括号
s = {1, 2, 3, 4, 5}
print(s)  # {1, 2, 3, 4, 5}

# 方法2:set()函数
s = set([1, 2, 2, 3, 3, 3])  # 自动去重
print(s)  # {1, 2, 3}

# 空集合(⚠️ 不能用{},那是空字典)
empty = set()

# 从字符串创建
chars = set("hello")
print(chars)  # {'h', 'e', 'l', 'o'}

2. 集合操作

python 复制代码
s = {1, 2, 3}

# 添加元素
s.add(4)
print(s)  # {1, 2, 3, 4}

# 删除元素
s.remove(2)  # 如果元素不存在会报错
print(s)  # {1, 3, 4}

s.discard(10)  # 元素不存在也不报错

# 检查成员
print(1 in s)   # True
print(10 in s)  # False

# 长度
print(len(s))  # 3

3. 集合运算

python 复制代码
a = {1, 2, 3, 4}
b = {3, 4, 5, 6}

# 并集
print(a | b)  # {1, 2, 3, 4, 5, 6}
print(a.union(b))

# 交集
print(a & b)  # {3, 4}
print(a.intersection(b))

# 差集
print(a - b)  # {1, 2}
print(a.difference(b))

# 对称差集
print(a ^ b)  # {1, 2, 5, 6}

🎯 在算法题中的应用

python 复制代码
# 第3课:最长连续序列
def longestConsecutive(nums):
    num_set = set(nums)  # O(1)查找
    longest = 0

    for num in num_set:
        # 只从序列起点开始
        if num - 1 not in num_set:
            current = num
            length = 1

            while current + 1 in num_set:
                current += 1
                length += 1

            longest = max(longest, length)

    return longest

# 去重
nums = [1, 2, 2, 3, 3, 3]
unique = list(set(nums))  # [1, 2, 3]

🎓 小结

{1, 2, 3} 创建集合

s.add(x) 添加元素

x in s O(1)查找

| & - ^ 集合运算

✅ 自动去重

核心优势: O(1)查找,类似字典但只存值不存键值对

下一步 : 09-字符串str.md


如果这篇内容对你有帮助,推荐收藏 AI Compass:https://github.com/tingaicompass/AI-Compass

更多系统化题解、编程基础和 AI 学习资料都在这里,后续复习和拓展会更省时间。

相关推荐
Yzzz-F4 小时前
Problem - 2146D1 - Codeforces &&Problem - D2 - Codeforces
算法
Kk.08024 小时前
力扣 LCR 084.全排列||
算法·leetcode·职场和发展
环黄金线HHJX.4 小时前
龙虾钳足启发的AI集群语言交互新范式
开发语言·人工智能·算法·编辑器·交互
Omics Pro4 小时前
虚拟细胞:开启HIV/AIDS治疗新纪元的关键?
大数据·数据库·人工智能·深度学习·算法·机器学习·计算机视觉
旖-旎5 小时前
分治(快速选择算法)(3)
c++·算法·leetcode·排序算法·快速选择
_日拱一卒5 小时前
LeetCode:合并区间
算法·leetcode·职场和发展
xiaoye-duck5 小时前
【C++:哈希表封装】哈希表封装 myunordered_map/myunordered_set 实战:底层原理 + 完整实现
数据结构·c++·散列表
汀、人工智能5 小时前
[特殊字符] 第3课:最长连续序列
数据结构·算法·数据库架构·图论·bfs·最长连续序列
少许极端5 小时前
算法奇妙屋(四十一)-贪心算法学习之路 8
学习·算法·贪心算法
Kethy__5 小时前
计算机中级-数据库系统工程师-数据结构-图
数据结构·算法·软考··数据库系统工程师·计算机中级