dict和set

dict:{ }

关键值:字典、键Key-值Value(键值对)、key不可变、value可变、无序

dict全称dictionary,在其他语言中也称为map(和map()函数不是一个概念),使用键-值(key-value)存储,具有极快的查找速度。

一个key只能对应一个value,多次对一个key放入value,后面的值会把前面的值冲掉。

常用方法:

(1)添加一个键值对:

{key} = value

(2)判断 key 是否存在

key in dict

(3)删除一个key,对应的value也被删除

pop(key)

dict内部存放的顺序和key放入的顺序是没有关系的。

和list比较,dict有以下几个特点:

查找和插入的速度极快,不会随着key的增加而变慢;

需要占用大量的内存,内存浪费多。

而list相反:

查找和插入的时间随着元素的增加而增加;

占用空间小,浪费内存很少。

所以,dict是用空间来换取时间的一种方法。

哈希算法(hash):通过key计算位置的算法称为哈希算法。

在Python中,字符串、整数等都是不可变的,因此,可以放心地作为key。而list是可变的,就不能作为key。

set:

关键词:不可重复、无序、配合list使用、只存不重复的Key、交并集

set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key。唯一区别,不存value。

要创建一个set,需要提供一个list作为输入集合:

s = set([1, 2, 3]) >>> {1, 2, 3} python2输出:([1,2,3])

set可以看成数学意义上的无序和无重复元素的集合,可以进行交、并集操作

& 交集

|  并集

常用方法:

(1)add(key)添加Key元素

(2)remove(key)删除Key元素

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容