数据容器集合set/frozenset

定义

可变集合(set):创建之后可以增删元素。

不可变集合(frozenset):创建之后不可以增删元素。

特点

内部元素无序(不保证顺序),不能通过下标访问元素。并且会自动去除重复元素。

可变集合的定义

集合中同时出现1和True,也是重复元素,python中bool值是int类型的子类型,用1表示True,用0表示False。

**并且每次打印的结果可能都是不一样的,这和Python底层保存的机制有关。**可能每次打印保存全部是数字的顺序每次都是一样的,但是换一个Python解释器,就可能和现在不一样了。

不可变集合的定义

实际就是将一个可变集合,强制装换为一个不可变集合。

frozenset函数接收的参数,可以是任意的可迭代对象,但是最终返回的一定是【不可变集合】。

定义集合

空集合

不可变集合的空集合很少用,因为不可变,后续也不能加元素。

注意事项

集合中只能放不可变的东西。

原因:因为集合底层是使用哈希表实现的,会通过元素计算哈希值,哈希值是不可变的。如果是集合的元素是可变的,那哈希值就会变化,就无法通过原理的哈希值找到元素了。

底层机制

相关推荐
Qres8214 小时前
算法复键——树状数组
数据结构·算法
牛油果子哥q6 小时前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒7 小时前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
WL学习笔记8 小时前
单项不带头不循环链表
数据结构·链表
小糯米6019 小时前
JS 数组
数据结构·算法·排序算法
小欣加油9 小时前
leetcode3612 用特殊操作处理字符串I
数据结构·c++·算法·leetcode·职场和发展
凌波粒9 小时前
LeetCode--90.子集II(回溯算法)
数据结构·算法·leetcode
凌波粒9 小时前
LeetCode--46.全排列(回溯算法)
数据结构·算法·leetcode
吃着火锅x唱着歌9 小时前
LeetCode 2530.执行K次操作后的最大分数
数据结构·算法·leetcode
CoderYanger10 小时前
A.每日一题:2095. 删除链表的中间节点
java·数据结构·程序人生·leetcode·链表·面试·职场和发展