栈和自定义异常

#!/usr/bin/env
class StackFullError(Exception):
    """
    自定义异常
    """
    pass


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


class Stack:
    """
    栈:先进后出
    比如用笼屉蒸包子,最底下一层是最先放的,但是最后拿出来的。
    """

    def __init__(self, size):
        """
        实例化对象
        :param size: 栈大小
        """
        self.size = size
        self.top = 0  # 栈指针位置
        self.lst = []  # 用list做栈

    def push(self, val):
        """
        往栈里面添加值
        1. 往栈指针所在位置添加值
        2. 添加成功以后,栈指针+1
        :param val:
        :return: null
        """
        if self.top == self.size:
            raise StackFullError("stack in full!!!")
        self.lst.insert(self.top, val)
        self.top += 1

    def get(self):
        """
        取栈里面的值,按栈顺序取
        1. 指针位置-1 获取到有值的栈位置
        2. 返回获取到值
        :return: val
        """
        if self.top == 0:
            raise StackNullError("stack in null!!!")
        self.top -= 1
        return self.lst[self.top]


obj = Stack(5)
obj.push("A")
obj.push("B")
obj.push("C")
obj.push("D")
obj.push("E")

print(obj.get())
print(obj.get())
print(obj.get())
print(obj.get())
print(obj.get())
print(obj.get())

 

转载于:https://www.cnblogs.com/spf21/p/10429368.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值