python 链式队列lqueue

"""
lqueue.py 链式队列
重点代码

思路分析:
1. 基于链表构建队列模型
2. 链表的开端作为队头,结尾位置作为对尾巴
3. 单独定义队尾标记,避免每次插入数据遍历
4. 队尾和队头重叠认为队列为空
"""


class QueueError(Exception):
    """
        自定义异常
    """
    pass


class Node:
    """
        节点类
    """

    def __init__(self, val, next=None):
        self.val = val
        self.next = next


class LQueue:
    """
        队列操作
        1. 基于链表构建队列模型
        2. 链表的开端作为队头,结尾位置作为对尾巴
        3. 单独定义队尾标记,避免每次插入数据遍历
        4. 队尾和队头重叠认为队列为空
    """

    def __init__(self):
        self.front = self.rear = Node(None)

    def is_empty(self):
        return self.front == self.rear

    def enqueue(self, val):
        # 入队
        self.rear.next = Node(val)
        self.rear = self.rear.next

    def dequeue(self):
        # 出队
        if self.is_empty():
            raise QueueError('Queue is empty')
        self.front = self.front.next
        return self.front.val

    def top(self):
        # 查看栈顶元素
        if self.is_empty():
            raise QueueError('Queue is empty')
        return self.front.next.val


if __name__ == '__main__':
    lq = LQueue()
    lq.enqueue(12)
    lq.enqueue(13)
    lq.enqueue(14)
    print(lq.dequeue())
    print(lq.dequeue())
    print(lq.top())

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值