python 链式队列lqueue

本文介绍了如何使用Python实现一个基于链表的队列(LQueue)数据结构,包括队列的初始化、空判断、入队(dequeue)、出队(enqueue)和查看栈顶(top)操作。通过实例展示了如何构造和操作链式队列,适合理解基础数据结构的读者。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

"""
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())

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值