Python数据结构队列的实现

队列结构:queue
生活例子:排队买票
队列的特点:先进先出(FirstInFirstOut,简称FIFO)
队列的基本用法:push(入队:添加元素) pop(出队:删除元素)
队列:Push、Pop、队列的大小、是否为空队列、清空队列  先进先出  双端队列:两端都能进,都能出
class Queue(object):
    # 先进先出
    # 在Python中用列表模拟队列
    def __init__(self):
        self.__queue = []

    def lpush(self, value):
        # 队头入队
        self.__queue.insert(0,value)

    def rpush(self, value):
        # 队尾入队
        self.__queue.append(value)

    def lpop(self):
        # 队头出队
        if self.__queue:
            return self.__queue.pop(0)
        return None

    def rpop(self):
        # 队尾出队
        if self.__queue:
            return self.__queue.pop()
        return None

    def size(self):
        # 队列长度
        return len(self.__queue)

    def is_empty(self):
        # 判断是否为空
        if self.__queue:
            return False
        return True

    def empty(self):
        # 清空队列
        self.__queue = []

queue = Queue()
queue.lpush("A")
queue.lpush("B")
queue.rpush("C")
queue.rpush("D")
queue.lpop()
queue.rpop()
print my_stack.size() 
print my_stack.is_empty() 
queue.empty()



  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值