Python之dictAndset

本文详细介绍了Python中字典(dict)和集合(set)的基本概念、定义方式、常见操作及其应用场景。对比了字典与列表在查找速度和内存占用方面的差异,并解释了如何利用这些特性进行高效编程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#dict 全称 dictionary,使用 key-value 储存,具有极快的查找速度

#1.0 定义

d = {'Michael':10,'Jerry':100,'Tracy':80}

print(d['Jerry'])#100


#1.1 由于一个key只能对应一个value,所以,多次对一个key放入value,后面的值会把前面的值冲掉:

d = {'Michael':10,'Jerry':100,'Tracy':80,'Jerry':80}

print(d['Jerry']) #80


#1.2.1 key 不存在时,dict 就会报错

#print(d['H'])

                #Traceback (most recent call last):

                #    File "<stdin>", line 1, in <module>

                #KeyError: 'H'

#1.2.2 可以通过 in 判断 key 是否存在

print('Jerry' in d) #True

print('H' in d) #False


#1.2.3 通过 dict get 方法判断 key 是否存在,不存在返回 None或者自己指定的value,存在返回 value

print(d.get('Jerry')) #80

print(d.get('J')) #None 注意在终端打印时,当返回的是 NonePython 的交互式命令行不显示结果

print(d.get('J',1)) #1


#1.3 删除一个 key,pop(key)方法,对应的 value 也会从 dict 中删除

d.pop('Tracy')

print(d)#{'Michael': 10, 'Jerry': 80}


#set set 也是一组 key 的集合,但是不储存 value,由于 key 不能重复,所以 set 中,没有重复的 key,且是无序的

#2.0 set 的定义

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

print(s) #{1, 2, 3}


#2.1 自动过滤重复元素

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

print(s) #{1, 2, 3, 100, 4}


#2.2 set 通过 add(key)方法增加元素,可以重复添加,但是会自动过滤重复的元素

s.add(400)

s.add(400)

print(s)#{1, 2, 3, 100, 4, 400}


#2.3 set 通过 remove(key)方法删除元素

s.remove(4)

print(s) #{1, 2, 3, 100, 400}


#2.4 set 相关的数学运算 可以看成数学意义上的无序和无重复元素的集合,因此,两个set可以做数学意义上的交集、并集等操作

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

s2 = set([2,3,4])

print(s1&s2) #{2, 3}


#总结:

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

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

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

#list相反:

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

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

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


#setdict的唯一区别仅在于没有存储对应的value,但是,set的原理和dict一样,所以,同样不可以放入可变对象,因为无法判断两个可变对象是否相等,也就无法保证set内部不会有重复元素


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值