Python--list,tuple,dict,set.

看Python基础,被那几个容器弄得晕乎乎的,对比总结下,以便记忆,可能是因为学Java就没有弄清楚集合那块的底层数据结构吧。

list:列表,用方括号[]表示,是有序的,增加和删除的速度很快,但是查询慢。里面的元素是可变的,即可以根据索引去改变对于位置的值。

(*我一直没弄懂它的有序是什么意思,我之前一直理解错了,以为有序就是按照自然排序的顺序有序,其实这个有序是按照你放入容器中的顺序来排序。所以list这类有序的东西,查找是很慢的。需要从头开始,挨个去容器里面找。容器越大,查找的速度就越慢,毕竟它需要挨个遍历容器。)

tuple:元组,用圆括号()表示,也是有序的。和list的区别是,它里面的元素是不可变的,不能增加,不能根据索引去改变对应位置的元素。因为不可变,所以相对list就更安全。

dict:字典,类似于Java的map的一种键值对的集合。使用大括号{}表示,是一种无序的集合,即元素放进去的时候的顺序和在内存中存放的顺序完全没有关系,它有自己的算法来计算元素在内存中的位置。key必须是唯一的而且必须是不可变对象(string,number,tuple),value可以不唯一,即可以多个value对应一个key。因为你每次去查询的时候,每次给函数一个key,内部会自动计算它在内存中的内存地址值,而直接去找那个value。但是,查询快的代价是内存消耗极大,所以是一种用空间来换时间的容器。

(之前看到一个例子就是,list和dict的查询,拿在字典中查找一个字为例,list就是拿着字典挨个去翻你要找的字;而dict就是先找到要找的字对应的页码,直接翻到对应的页去找那个字。)

set:集合,也跟Java的set一样无序不重复(跟数学的定义也一样),也是用大括号{}表示,只是dict 的大括号里面是键值对的形式,set里面相当于只放了key,而没有对应的value。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值