Python编程题31--用列表实现队列

2021/11/27 14:09:50

本文主要是介绍Python编程题31--用列表实现队列,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

题目

队列是一种常见的数据结构,其特点是 先进先出,并且只能从队尾进队头出,也就是说最先放进去的元素,能够最先取出来。

请使用 列表list 模拟实现队列的下列操作:

  • push(x) -- 将元素 x 推到队列的末尾
  • pop() -- 从队列开头移除元素
  • peek() -- 返回队列开头的元素
  • empty() -- 判断队列是否为空
  • size() -- 获取队列的长度

说明:假设每次调用 pop 和 peek 都能保证队列不为空。

代码实现

class MyQueue:

    def __init__(self):
        self.q = []

    def push(self, x):
        self.q.append(x)

    def pop(self):
        self.q.pop(0)

    def peek(self):
        return self.q[0]

    def empty(self):
        return self.q == []

    def size(self):
        return len(self.q)

测试过程

if __name__ == '__main__':
    queue = MyQueue()
    queue.push(11)  # 入队
    queue.push(22)  # 入队
    print(queue.peek())
    print(queue.size())
    queue.pop()  # 出队
    print(queue.empty())
    print(queue.peek())
    queue.pop()  # 出队
    print(queue.size())
    print(queue.empty())

执行代码后,得到如下结果:

11
2
False
22
0
True


这篇关于Python编程题31--用列表实现队列的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程