如何使用Python中的collections模块提供的数据结构,如deque、Counter、OrderedDict等

Python 的 collections 模块提供了一些额外的数据结构,这些数据结构在内置的数据类型(如列表、字典、集合等)的基础上,增加了额外的功能或优化了性能。下面是如何使用 collections 模块中的 dequeCounterOrderedDict 这三种数据结构的简单示例。

1. deque(双端队列)

deque(发音为"deck")是一个线程安全、快速添加/删除元素于两端的线性容器。它支持从两端快速添加和删除元素,时间复杂度为 O(1)。

复制代码

python复制代码

|---|--------------------------------------------------------------|
| | from collections import deque |
| | |
| | # 创建一个 deque |
| | d = deque('ghi') |
| | |
| | # 添加元素到右端 |
| | d.append('j') |
| | d.append('k') |
| | |
| | # 添加元素到左端 |
| | d.appendleft('f') |
| | d.appendleft('e') |
| | |
| | # 打印 deque |
| | print(d) # 输出: deque(['e', 'f', 'g', 'h', 'i', 'j', 'k']) |
| | |
| | # 从右端移除元素 |
| | print(d.pop()) # 输出: 'k' |
| | |
| | # 从左端移除元素 |
| | print(d.popleft()) # 输出: 'e' |

2. Counter(计数器)

Counter 是一个字典子类,用于计数可哈希对象。它是一个字典,其中元素被当作字典键,它们的计数被存储为字典值。

复制代码

python复制代码

|---|---------------------------------------------------------------------------------------------|
| | from collections import Counter |
| | |
| | # 创建一个 Counter |
| | c = Counter('gallahad') |
| | |
| | # 输出 Counter |
| | print(c) # 输出: Counter({'a': 3, 'l': 2, 'g': 1, 'h': 1, 'd': 1}) |
| | |
| | # 更新计数器 |
| | c.update('admiral') |
| | |
| | # 输出更新后的 Counter |
| | print(c) # 输出: Counter({'a': 4, 'd': 2, 'l': 2, 'g': 1, 'm': 1, 'i': 1, 'r': 1, 'h': 1}) |
| | |
| | # 获取某个元素的计数 |
| | print(c['a']) # 输出: 4 |
| | |
| | # 获取元素计数并删除该元素(如果计数为 0,则不执行删除) |
| | print(c.pop('d')) # 输出: 2 |
| | |
| | # 输出更新后的 Counter |
| | print(c) # 输出: Counter({'a': 4, 'l': 2, 'g': 1, 'm': 1, 'i': 1, 'r': 1, 'h': 1}) |

3. OrderedDict(有序字典)

OrderedDict 是一个字典子类,它保持了元素被插入时的顺序。当迭代 OrderedDict 时,元素的顺序与它们被插入时的顺序相同。

复制代码

python复制代码

|---|----------------------------------------|
| | from collections import OrderedDict |
| | |
| | # 创建一个 OrderedDict |
| | d = OrderedDict() |
| | d['foo'] = 1 |
| | d['bar'] = 2 |
| | d['spam'] = 3 |
| | d['grok'] = 4 |
| | |
| | # 迭代并打印 OrderedDict |
| | for key in d: |
| | print(key, d[key]) |
| | # 输出: |
| | # foo 1 |
| | # bar 2 |
| | # spam 3 |
| | # grok 4 |
| | |
| | # 插入一个新的键值对到有序字典的开始 |
| | d.move_to_end('foo', last=False) |
| | |
| | # 再次迭代并打印 |
| | for key in d: |
| | print(key, d[key]) |
| | # 输出: |
| | # foo 1 |
| | # bar 2 |
| | # spam 3 |
| | # grok 4 |

这些数据结构在需要特定功能的场景下非常有用,如需要维护插入顺序的字典、需要快速从两端添加/删除元素的列表,或者需要计数可哈希对象的场景。

相关推荐
梦想平凡15 分钟前
情怀源代码工程实践(加长版 1/3):确定性内核、事件回放与最小可运行骨架
开发语言·javascript·ecmascript
笑我归无处25 分钟前
强引用、软引用、弱引用、虚引用详解
java·开发语言·jvm
02苏_25 分钟前
秋招Java面
java·开发语言
Q_Q196328847529 分钟前
python+django/flask基于机器学习的就业岗位推荐系统
spring boot·python·django·flask·node.js·php
ytttr87333 分钟前
64QAM信号的数字预失真处理(MATLAB实现)
开发语言·matlab
Nebula_g38 分钟前
C语言应用实例:硕鼠游戏,田忌赛马,搬桌子,活动选择(贪心算法)
c语言·开发语言·学习·算法·游戏·贪心算法·初学者
爱吃甜品的糯米团子1 小时前
详解 JavaScript 内置对象与包装类型:方法、案例与实战
java·开发语言·javascript
liu****1 小时前
11.Linux进程信号(三)
linux·运维·服务器·数据结构·1024程序员节
郝学胜-神的一滴1 小时前
Linux下,获取子进程退出值和异常终止信号
linux·服务器·开发语言·c++·程序人生