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 学习资料都在这里,后续复习和拓展会更省时间。

相关推荐
To_OC16 小时前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode
刘马想放假1 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
05Kevin1 天前
lk每日冒险题--数据结构6.27
算法
To_OC2 天前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
千纸鹤安安2 天前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法
七牛开发者2 天前
MCP 到底是什么?为什么 Agent 都想接上它
算法·aigc·agent
北域码匠2 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法