Python deque:高效地进行双端操作

一、概述

Python deque(双端队列)是Python标准库collections模块中的一个数据容器,它是一种具有线性表的性质,并且可以在队列的两端进行添加和删除元素。与列表相比,deque除了支持队列和栈的操作,还提供了旋转、均摊复杂度为O(1)的appendleft和popleft方法。

有时候我们需要使用队列,找到最前面/最后面的项目,或者需要从中删除一些项目,那么deque就可以派上用场。deque是一个双端队列,可以在队列的头部或尾部快速插入和删除元素,具有高效地进行双端操作的特性。

二、deque基础使用

Deque实例可以从左端和右端添加或删除元素。更具体来说,在deque开头添加和删除元素是O(1)的操作,但将一个元素插入中间是比较慢的,因为它需要移动内部元素以为新元素腾出空间。以下是deque的基本操作。


from collections import deque

d = deque()
d.append('a')           # 添加到队列右侧
d.appendleft('b')       # 添加到队列左侧
d.extend(['c', 'd'])    # 在队列右侧添加多个元素
d.extendleft(['e', 'f'])# 在队列左侧添加多个元素

print(d)                # deque(['f', 'e', 'b', 'a', 'c', 'd'])

d.pop()                 # 从队列右侧删除元素
d.popleft()             # 从队列左侧删除元素

print(d)                # deque(['b', 'a', 'c'])

三、deque的高效性

deque作为一个双端队列,在队列两端同时添加和删除元素的时候具有高效性。例如,可以使用deque在一个大数组上模拟一个滑动窗口,下面我们通过一个例子来演示deque的高效性。

我们有一个长度为100,000的列表,要在其中找到长度为100的最大子序列。假设我们用列表进行求解的话,代码会是这样的:


a = [...]    # 长度为100,000的列表
k = 100

largest_sum = float('-inf')
for i in range(len(a)-k):
    current_sum = sum(a[i:i+k])
    largest_sum = max(largest_sum, current_sum)

在上面的代码中,我们遍历了列表中的每个子序列,并在其中找到了最大子序列。但是由于要遍历很多子序列,时间复杂度为O(n * k)。

改用deque,我们可以将时间复杂度降至O(n),如下所示。


from collections import deque

a = [...]         # 长度为100,000的列表
k = 100

d = deque()
largest_sum = float('-inf')
for i, item in enumerate(a):
    # 弹出过期数据
    if len(d) == k:
        d.popleft()

    # 加入新数据
    d.append(item)

    if len(d) == k:
        current_sum = sum(d)
        largest_sum = max(largest_sum, current_sum)

在上面的代码中,我们使用deque维护了一个长度为100的滑动窗口,时间复杂度为O(n),具有比上面使用列表更高的效率。

四、deque的其他用途

除了作为双端队列,deque还有其他的用途。比如,在操作系统中,deque被用来存储系统调用。在图形学和游戏中,deque被用来存储和管理动画帧。在Web框架中,deque被用来存储客户请求和消息日志。

五、总结

deque是Python标准库中的一个双端队列,具有线性表的性质,并且可以在队列的两端进行添加和删除元素。与列表相比,deque除了支持队列和栈的操作,还提供了旋转、均摊复杂度为O(1)的appendleft和popleft方法。deque可用于从队列中查找最前面/最后面的项目,或者需要从中删除一些项目,具有高效地进行双端操作的特性。该数据容器在操作系统、游戏等领域有广泛应用。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/182180.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-11-24 06:19
下一篇 2024-11-24 06:19

相关推荐

  • Python列表中负数的个数

    Python列表是一个有序的集合,可以存储多个不同类型的元素。而负数是指小于0的整数。在Python列表中,我们想要找到负数的个数,可以通过以下几个方面进行实现。 一、使用循环遍历…

    编程 2025-04-29
  • Python周杰伦代码用法介绍

    本文将从多个方面对Python周杰伦代码进行详细的阐述。 一、代码介绍 from urllib.request import urlopen from bs4 import Bea…

    编程 2025-04-29
  • 如何查看Anaconda中Python路径

    对Anaconda中Python路径即conda环境的查看进行详细的阐述。 一、使用命令行查看 1、在Windows系统中,可以使用命令提示符(cmd)或者Anaconda Pro…

    编程 2025-04-29
  • Python计算阳历日期对应周几

    本文介绍如何通过Python计算任意阳历日期对应周几。 一、获取日期 获取日期可以通过Python内置的模块datetime实现,示例代码如下: from datetime imp…

    编程 2025-04-29
  • Python中引入上一级目录中函数

    Python中经常需要调用其他文件夹中的模块或函数,其中一个常见的操作是引入上一级目录中的函数。在此,我们将从多个角度详细解释如何在Python中引入上一级目录的函数。 一、加入环…

    编程 2025-04-29
  • Python程序需要编译才能执行

    Python 被广泛应用于数据分析、人工智能、科学计算等领域,它的灵活性和简单易学的性质使得越来越多的人喜欢使用 Python 进行编程。然而,在 Python 中程序执行的方式不…

    编程 2025-04-29
  • Python清华镜像下载

    Python清华镜像是一个高质量的Python开发资源镜像站,提供了Python及其相关的开发工具、框架和文档的下载服务。本文将从以下几个方面对Python清华镜像下载进行详细的阐…

    编程 2025-04-29
  • 蝴蝶优化算法Python版

    蝴蝶优化算法是一种基于仿生学的优化算法,模仿自然界中的蝴蝶进行搜索。它可以应用于多个领域的优化问题,包括数学优化、工程问题、机器学习等。本文将从多个方面对蝴蝶优化算法Python版…

    编程 2025-04-29
  • python强行终止程序快捷键

    本文将从多个方面对python强行终止程序快捷键进行详细阐述,并提供相应代码示例。 一、Ctrl+C快捷键 Ctrl+C快捷键是在终端中经常用来强行终止运行的程序。当你在终端中运行…

    编程 2025-04-29
  • Python字典去重复工具

    使用Python语言编写字典去重复工具,可帮助用户快速去重复。 一、字典去重复工具的需求 在使用Python编写程序时,我们经常需要处理数据文件,其中包含了大量的重复数据。为了方便…

    编程 2025-04-29

发表回复

登录后才能评论