Python 中的 `deque` 用法介绍

本文介绍了Pythoncollections模块中的deque数据结构,包括其创建、添加、删除元素的方法,以及访问、遍历和检查状态的功能,强调了其在需要快速操作两端元素场景中的优势。
摘要由CSDN通过智能技术生成

deque(双端队列)是 Python collections 模块中的一个数据结构,它允许你在队列的两端进行添加(append)和弹出(pop)操作。deque 是一个线程安全的双向链表,适用于需要快速添加和删除元素的场景。以下是 deque 的一些基本用法和特性。

1. 创建 deque

要使用 deque,首先需要从 collections 模块中导入它,然后创建一个 deque 实例。

from collections import deque

# 创建一个空的 deque
dq = deque()

你也可以通过传递一个序列(如列表)来创建一个 deque

# 创建一个包含元素的 deque
dq = deque([1, 2, 3, 4, 5])

2. 添加元素

deque 提供了多种方法来添加元素。

  • append(x): 在 deque 的右端添加一个元素。
  • appendleft(x): 在 deque 的左端添加一个元素。
# 在右端添加元素
dq.append(6)

# 在左端添加元素
dq.appendleft(0)

3. 删除元素

deque 也提供了方法来删除元素。

  • pop(): 移除并返回 deque 右端的元素。如果未指定 n,则默认为 0。
  • popleft(): 移除并返回 deque 左端的元素。如果未指定 n,则默认为 0。
# 删除并返回右端的元素
rightmost_element = dq.pop()

# 删除并返回左端的元素
leftmost_element = dq.popleft()

4. 访问元素

deque 提供了方法来访问但不删除元素。

  • first: 返回 deque 左端的元素,但不删除它。
  • last: 返回 deque 右端的元素,但不删除它。
# 获取左端的元素
first_element = dq[0]

# 获取右端的元素
last_element = dq[-1]

5. 其他方法

deque 还提供了其他有用的方法。

  • extend(iterable): 将一个可迭代对象的所有元素添加到 deque 的右端。
  • extendleft(iterable): 将一个可迭代对象的所有元素添加到 deque 的左端。
  • rotate(n=1): 向右旋转 deque 中的元素 n 步。如果 n 为负数,则向左旋转。
# 将列表中的元素添加到 deque 的左端
dq.extendleft([7, 8, 9])

# 旋转 deque,将右端的元素移动到左端
dq.rotate()

6. 遍历 deque

你可以使用 for 循环来遍历 deque 中的元素。

# 遍历 deque 并打印每个元素
for element in dq:
    print(element)

7. 检查 deque 的状态

deque 提供了一些方法来检查其状态。

  • empty(): 如果 deque 为空,则返回 True
  • count(x): 返回 deque 中元素 x 出现的次数。
# 检查 deque 是否为空
is_empty = dq.empty()

# 计算某个元素在 deque 中出现的次数
element_count = dq.count(3)

结论

deque 是 Python 中一个非常有用的数据结构,特别适合于需要两端快速添加和删除的场景。它的使用简单直观,而且性能高效。在处理需要频繁变更的数据集合时,deque 是一个很好的选择。

水平有限,有问题随时交流;

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python,deque是一个双端队列数据结构,可以在两端进行插入和删除操作。通过引用可以得知,在CPython,deque的append()、appendleft()、pop()、popleft()以及len(d)操作是线程安全的。这意味着这些操作可以在多线程环境下使用而不会引起竞争条件。另外,引用提到了使用deque类时,可以通过列表来实现双端队列,并且deque类提供了许多方法来操作队列。例如,可以使用append()和appendleft()方法在队列的末尾和开头插入元素,使用pop()和popleft()方法从队列的末尾和开头删除元素。此外,还可以使用len()函数获取队列的长度。引用给出了一个具体的例子,展示了如何创建一个指定长度的deque对象,并且使用extend()、append()和appendleft()方法向队列添加元素。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [python的deque](https://blog.csdn.net/weixin_44835655/article/details/127335718)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Python deque的用法介绍](https://blog.csdn.net/weixin_43790276/article/details/107749745)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值