0

0

python中deque双端队列怎么用?

穿越時空

穿越時空

发布时间:2025-09-14 23:09:01

|

498人浏览过

|

来源于php中文网

原创

deque是Python中高效处理双端操作的队列结构,适用于频繁在两端增删元素的场景。它支持append、appendleft、pop、popleft等基本操作,时间复杂度均为O(1),性能优于list。通过maxlen参数可实现固定长度的滑动窗口,超出时自动从对端移除元素。deque不支持线程安全,多线程环境下需配合锁机制使用。适合用于实现队列、栈、缓冲区等数据结构。

python中deque双端队列怎么用?

Python的

deque
(双端队列)允许你高效地在队列的两端添加和移除元素。它特别适用于需要频繁进行头尾操作的场景,比如实现队列、栈或者需要快速访问两端元素的滑动窗口。
deque
collections
模块中。

使用

deque
,你可以轻松地进行元素的添加、删除,并且它在这些操作上的性能通常优于使用
list

解决方案(直接输出解决方案即可)

deque
的基本操作包括:

  • append(x)
    : 在队列右端添加元素
    x
  • appendleft(x)
    : 在队列左端添加元素
    x
  • pop()
    : 移除并返回队列右端的元素。
  • popleft()
    : 移除并返回队列左端的元素。
  • extend(iterable)
    : 从队列右端添加
    iterable
    中的元素。
  • extendleft(iterable)
    : 从队列左端添加
    iterable
    中的元素 (注意:元素顺序会反转)。
  • rotate(n)
    : 将队列中的元素向右循环移动
    n
    步。 如果
    n
    是负数,则向左移动。
  • clear()
    : 移除队列中的所有元素。
  • count(x)
    : 返回队列中等于
    x
    的元素个数。
  • remove(value)
    : 移除队列中第一个等于
    value
    的元素。 如果没有找到,则引发
    ValueError
  • reverse()
    : 反转队列中的元素顺序。

示例代码:

立即学习Python免费学习笔记(深入)”;

from collections import deque

# 创建一个deque
d = deque()

# 从右端添加元素
d.append(1)
d.append(2)
d.append(3)

# 从左端添加元素
d.appendleft(0)

print(d)  # 输出: deque([0, 1, 2, 3])

# 移除右端元素
d.pop()

# 移除左端元素
d.popleft()

print(d)  # 输出: deque([1, 2])

# 扩展队列
d.extend([4, 5, 6])
print(d) # deque([1, 2, 4, 5, 6])

# 从左边扩展队列 (注意顺序反转)
d.extendleft([-1, -2, -3])
print(d) # deque([-3, -2, -1, 1, 2, 4, 5, 6])

# 旋转队列
d.rotate(2)  # 向右旋转2步
print(d) # deque([5, 6, -3, -2, -1, 1, 2, 4])

d.rotate(-2) # 向左旋转2步
print(d) # deque([-3, -2, -1, 1, 2, 4, 5, 6])

# 统计元素个数
print(d.count(2)) # 1

# 移除指定元素
d.remove(2)
print(d) # deque([-3, -2, -1, 1, 4, 5, 6])

# 反转队列
d.reverse()
print(d) # deque([6, 5, 4, 1, -1, -2, -3])

# 清空队列
d.clear()
print(d) # deque([])

何时应该使用
deque
而不是
list

当你的主要操作涉及在序列的两端添加或删除元素时,

deque
通常是更好的选择。
list
在这些操作上的时间复杂度是O(n),因为可能需要移动其他元素。而
deque
在两端添加或删除元素的时间复杂度是O(1),这使得它在处理大量数据时效率更高。 但如果你需要频繁地通过索引访问元素,
list
通常会更快,因为
list
的索引访问是O(1),而
deque
是O(n)。

慧中标AI标书
慧中标AI标书

慧中标AI标书是一款AI智能辅助写标书工具。

下载

deque
如何实现线程安全?

deque
本身不是线程安全的。这意味着如果在多个线程中同时修改同一个
deque
对象,可能会导致数据竞争和不确定的行为。为了在多线程环境中使用
deque
,你需要使用适当的同步机制,比如锁。

import threading
from collections import deque

d = deque()
lock = threading.Lock()

def add_element(element):
    with lock:
        d.append(element)
        print(f"Added {element}, current deque: {d}")

def remove_element():
    with lock:
        if d:
            element = d.popleft()
            print(f"Removed {element}, current deque: {d}")
        else:
            print("Deque is empty")

# 示例:两个线程同时添加和删除元素
t1 = threading.Thread(target=add_element, args=(1,))
t2 = threading.Thread(target=remove_element)

t1.start()
t2.start()

t1.join()
t2.join()

print("Final deque:", d)

在这个例子中,

threading.Lock()
用于确保在任何时候只有一个线程可以访问和修改
deque
with lock:
语句块会自动获取和释放锁,从而避免了手动管理锁的复杂性。

deque
maxlen
参数有什么用?

deque
有一个可选的
maxlen
参数,用于限制队列的最大长度。当
deque
达到最大长度时,如果继续添加元素,则会自动从另一端移除元素。这在实现固定大小的滑动窗口或缓冲区时非常有用。

from collections import deque

# 创建一个最大长度为3的deque
d = deque(maxlen=3)

d.append(1)
d.append(2)
d.append(3)

print(d)  # 输出: deque([1, 2, 3], maxlen=3)

# 添加新元素,最左边的元素会被移除
d.append(4)
print(d)  # 输出: deque([2, 3, 4], maxlen=3)

d.appendleft(0)
print(d) # deque([0, 2, 3], maxlen=3)

在这个例子中,当

deque
达到最大长度3时,添加新元素会自动从另一端移除旧元素,从而保持队列的大小不变。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

769

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

661

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

764

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

639

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1325

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

549

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

579

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

709

2023.08.11

Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

9

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1.0万人学习

PHP自制框架
PHP自制框架

共8课时 | 0.6万人学习

PHP入门到实战消息队列RabbitMQ
PHP入门到实战消息队列RabbitMQ

共22课时 | 1.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号