Python数据结构与算法的双端队列详解

 更新时间:2022年03月09日 16:51:58   作者:姜学迁  
这篇文章主要为大家详细介绍了Python的双端队列,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助

什么是双端队列​

双端队列是与队列类似的有序集合。它有一、一两端,元素在其中保持自己的位置。与队列不同的是,双端队列对在哪一端添加和移除元素没有任何限制。新元素既可以被添加到前端,也可以被添加到后端。同理,已有的元素也能从任意一端移除。某种意义上,双端队列可以是栈和队列的结合。

在这里插入图片描述

值得注意的是,尽管双端队列有栈和队列的很多特性,但是它并不要求按照这两种数据结构分别规定的LIFO原则和FIFO原则操作元素。具体的排序原则取决于其使用者。

​双端队列抽象数据类型由下面的结构和操作定义。如前所述,双端队列是元素的有序集合,其任何一端都允许添加或移除元素。双端队列支持以下操作:

  • 创建一个空的双端队列。它不需要参数,且会返回一个空的双端队列。 Deque()
  • 将一个元素添加到双端队列的前端。它接受一个元素作为参数,没有返回值。 addFront(item)
  • 将一个元素添加到双端队列的后端。它接受一个元素作为参数,没有返回值。 addRear(item)
  • 从双端队列的前端移除一个元素。它不需要参数,且会返回一个元素,并修改双端队列的内容。 removeFront()
  • 从双端队列的后端移除一个元素。它不需要参数,且会返回一个元素, 并修改双端队列的内容。 removeRear()
  • 检查双端队列是否为空。它不需要参数,且会返回一个布尔值。 isEmpty()
  • 返回双端队列中元素的数目。它不需要参数,且会返回一个整数。 size()

​用Python实现双端队列

我们通过创建一个新类来实现双端队列抽象数据类型。Python列表再一次提供了 很多简便的方法来帮助我们构建双端队列。在下面的代码中,我们假设双端队列的后端是列表的位置0处(列表的最左端)。

class Deque:
    def __init__(self):
        self.items = []
    def isEmpty(self):
        return self.items == []
    # 往双端队列前端添加元素
    def addFront(self, item):
        self.items.append(item)
    # 往双端队列后端添加元素
    def addRear(self, item):
        self.items.insert(0, item)
    # 在前端移除双端队列元素
    def removeFront(self):
        return self.items.pop()
    # 在后端移除双端队列元素
    def removeRear(self):
        return self.items.pop(0)
    def size(self):
        return len(self.items)
    def look(self):
        print(self.items)

removeFront 使用 pop 方法移除列表中的最后一个元素,removeRear 则使用 pop(0) 方法移除列表中的第一个元素。同理,之所以 addRear 使用 insert 方法,是因为 append 方法只能在列表的最后(最右端)添加元素。​

代码运行效果如下:

在这里插入图片描述

运用双端队列构建回文检测器

我们现在运用双端队列解决一个非常有趣的经典问题:回文问题。回文是指从前往后读和从后往前读都一样的字符串,例如 sos、radar、toot、madam 等等。我们将构建一个程序,它接受一个字符串并且检测其是否为回文。​

该问题的解决方案是使用一个双端队列来存储字符串中的字符。按照从左往右的顺序将字符串中的字符添加到双端队列的后端或前端。此时,该双端队列类似于一个普通的队列。​

由于可以从前后两端移除元素,因此我们能够比较两个元素,并且只有在二者相等时才继续。如果一直匹配第一个和最后一个元素,最终会处理完所有的字符(如果字符数是偶数),或者剩下只有一个元素的双端队列(如果字符数是奇数)。任意一种结果都表明输入字符串是回文。​

回文检测器代码如下:

class Deque:
    def __init__(self):
        self.items = []
    def isEmpty(self):
        return self.items == []
    def addFront(self, item):
        self.items.append(item)
    def addRear(self, item):
        self.items.insert(0, item)
    def removeFront(self):
        return self.items.pop()
    def removeRear(self):
        return self.items.pop(0)
    def size(self):
        return len(self.items)

def palchecker(aString):
    chardeque = Deque()
    for ch in aString:
        chardeque.addFront(ch)
    stillEqual = True
    while chardeque.size() > 1 and stillEqual:
        first = chardeque.removeFront()
        last = chardeque.removeRear()
        if first != last:
            stillEqual = False
    return stillEqual

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容!   

相关文章

  • 帮你快速上手Jenkins并实现自动化部署

    帮你快速上手Jenkins并实现自动化部署

    在未学习Jenkins之前,只是对Jenkins有一个比较模糊的理解,即Jenkins是一个自动化构建项目发布的工具,可以实现代码->github或者gitlab库->jenkins自动部署->访问的整体的过程,而无需人为重新打包,今天就带大家详细了解一下,帮你快速上手Jenkins,需要的朋友可以参考下
    2021-06-06
  • python实现简单http服务器功能

    python实现简单http服务器功能

    这篇文章主要为大家详细介绍了python实现简单http服务器功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-09-09
  • Python时间戳与时间字符串互相转换实例代码

    Python时间戳与时间字符串互相转换实例代码

    这篇文章主要介绍了Python时间戳与时间字符串互相转换实例代码,大家参考使用
    2013-11-11
  • python如何利用traceback获取详细的异常信息

    python如何利用traceback获取详细的异常信息

    异常信息的获取对于程序的调试非常重要,可以有助于快速定位有错误程序语句的位置。这篇文章主要给大家介绍了关于python如何利用traceback获取详细的异常信息的相关资料,需要的朋友可以参考下
    2021-06-06
  • 2020年10款优秀的Python第三方库,看看有你中意的吗?

    2020年10款优秀的Python第三方库,看看有你中意的吗?

    2020已经过去,在过去的一年里,又有非常多优秀的Python库涌现出来。相对于numpy、TensorFlow、pandas这些已经经过多年维护、迭代,对于大多数Python开发者耳熟能详的库不同。
    2021-01-01
  • python如何使用腾讯云发送短信

    python如何使用腾讯云发送短信

    这篇文章主要介绍了python如何使用腾讯云发送短信,帮助大家更好的理解和使用python,感兴趣的朋友可以了解下
    2020-09-09
  • 如何在Python中将字符串转换为数组详解

    如何在Python中将字符串转换为数组详解

    最近在用Python,做一个小脚本,有个操作就是要把内容换成数组对象再进行相关操作,下面这篇文章主要给大家介绍了关于如何在Python中将字符串转换为数组的相关资料,需要的朋友可以参考下
    2022-12-12
  • python字符串加密解密的三种方法分享(base64 win32com)

    python字符串加密解密的三种方法分享(base64 win32com)

    这篇文章主要介绍了python字符串加密解密的三种方法,包括用base64、使用win32com.client、自己写的加密解密算法三种方法,大家参考使用吧
    2014-01-01
  • python使用pip安装SciPy、SymPy、matplotlib教程

    python使用pip安装SciPy、SymPy、matplotlib教程

    今天小编大家分享一篇python使用pip安装SciPy、SymPy、matplotlib教程,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-11-11
  • 用Python实现读写锁的示例代码

    用Python实现读写锁的示例代码

    这篇文章主要介绍了用Python实现读写锁的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-11-11

最新评论