python练习:栈和队列的封装

本文介绍了如何利用Python内置的列表数据结构封装栈和队列。栈的实现包括了push、pop、is_empty和top等方法,而队列则包含enqueue、dequeue、is_empty和top方法。通过示例展示了如何操作这两个数据结构,如入栈、出栈、入队、出队等操作。
摘要由CSDN通过智能技术生成

用list实现栈和队列

一.栈的封装

class Stack(object):
    """以list为基础封装栈数据结构"""

    def __init__(self):
        # []左侧(栈底)不能增删改,右侧(栈顶)可以增删改
        self.stack = []

    def push(self, val):
        """入栈"""
        self.stack.append(val)

    def pop(self):
        """出栈"""
        if self.is_empty():
            return 'error'
        item = self.stack.pop()
        return item

    def is_empty(self):
        """判断栈是否为空"""
        return len(self.stack) == 0

    def top(self):
        """获取栈顶元素"""
        if self.is_empty():
            return 'error'
        return self.stack[-1]

    def __len__(self):
        """获取栈元素"""
        # 魔术方法,当执行len(obj)自动执行的方法
        # 拓展(魔术方法):http://c.biancheng.net/view/7817.html
        return len(self.stack)

    def __str__(self):
        return ",".join([str(i) for i in self.stack])

s = Stack()
s.push(5)
s.push(3)
# print(len(s))  # [5, 3]
# print(s.pop())
# print(s.is_empty())  # [5]
# print(s.pop())  # []
# print(s.is_empty())  # []
# print(s.pop())

print(str(s))

二.队列的封装

class Queue(object):
    """以list为基础封装队列数据结构"""

    def __init__(self):
        # []左侧(队头)只能删除,右侧(队尾)可以增
        self.queue = []

    def enqueue(self, val):
        """入队列"""
        self.queue.append(val)

    def dequeue(self):
        """出队列"""
        if self.is_empty():
            return 'error'
        item = self.queue.pop(0)
        return item

    def is_empty(self):
        """判断队列是否为空"""
        return len(self.queue) == 0

    def top(self):
        """获取队头元素"""
        if self.is_empty():
            return 'error'
        return self.queue[0]

    def __len__(self):
        """获取队列元素"""
        # 魔术方法,当执行len(obj)自动执行的方法
        # 拓展(魔术方法):http://c.biancheng.net/view/7817.html
        return len(self.queue)

    def __str__(self):
        return ",".join([str(i) for i in self.queue])

q = Queue()
q.enqueue(5)
q.enqueue(3)
print(str(q))
print(len(q))
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值