python中的四个经典容器简单介绍

python中的四个经典容器list和tuple dict和set

因为特别容易混淆,所以简单整理一下。
1 list:可变有序列表,可随时添加和删除元素。
表示方法:

classmates = ['tom','bob','tracy']

相关方法:
获取长度:len()
添加元素:appen()
插入元素到指定位置:insert(i, 'Jack')
删除list末尾元素:pop()
删除指定位置元素:pop(i)
list里面元素的数据类型可以不同(可以装list)

2 tuple 不可变有序列表 元组 一旦初始化后就不可修改(tuple所谓的“不变”是说,tuple的每个元素,指向永远不变)。
表示方法:

classmates = ('Michael', 'Bob', 'Tracy')

无添加,插入方法,更安全。
定义一个元素的元组:t = (1,)

3 dict 字典 使用键-值(key-value)存储无序,key不能重复,具有极快的查找速度。
表示方法:

 d = {'Michael': 95, 'Bob': 75, 'Tracy': 85}

通过dict提供的get()方法,如果key不存在(会报错),可以返回None,或者自己指定的value:

 d.get('Thomas', -1) 

删除指定元素:d.pop(‘Bob’)
注意,dict内部存放的顺序和key放入的顺序是没有关系的
和list比较,dict有以下几个特点:
查找和插入的速度极快,不会随着key的增加而变慢;
需要占用大量的内存,内存浪费多。
而list相反:
查找和插入的时间随着元素的增加而增加;
占用空间小,浪费内存很少。
dict的key必须是不可变对象,通过key计算位置的算法称为哈希算法(Hash)

4 set 和dict类似,不存储value,key不能重复,无序和无重复元素的集合。
要创建一个set,需要提供一个list作为输入集合:

s = set([1, 2, 3])

显示的顺序不表示set是有序的,重复元素在set中被自动过滤。
添加元素:add(key)
删除元素:remove(key)
set的原理和dict一样,所以,同样不可以放入可变对象,因为无法判断两个可变对象是否相等,也就无法保证set内部“不会有重复元素”

参考:https://www.liaoxuefeng.com/wiki/1016959663602400/1017092876846880
https://www.liaoxuefeng.com/wiki/1016959663602400/1017104324028448
如有侵权,请联系删除,谢谢!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值