2023-12-08 队列与栈

栈与队列一

232. 用栈实现队列

思路:对于使用栈实现队列的话,必须使用两个共同来维护使得每次都能先进先出!

232.用栈实现队列版本2

class MyQueue:

    def __init__(self):
        # 需要建立两个list来维护出栈以及进栈
        self.stack_in = []
        self.stack_out = []

    def push(self, x: int) -> None:
        self.stack_in.append(x)

    def pop(self) -> int:
        if  self.empty():
            return None
        # 判断出栈是否有元素
        if self.stack_out:
            return self.stack_out.pop()
        else:
            for i in range(len(self.stack_in)):
                self.stack_out.append(self.stack_in.pop())
        return self.stack_out.pop()

    def peek(self) -> int:
        # 使用list来做,末尾就头 为什么使用pop捏?是为了避免反复进行空的判断!不要代码冗余
        ans = self.pop()
        self.stack_out.append(ans)
        return ans

    def empty(self) -> bool:
        # 只需要两个栈其中一个不为零就可
        return not (self.stack_in or self.stack_out)

225. 用队列实现栈

思路:这个比较简单了,简单维护一个队里就可以了!
class MyStack:

    def __init__(self):
        self.queue = []

    def push(self, x: int) -> None:
        self.queue.append(x)

    def pop(self) -> int:
        if self.empty():
            return None
        return self.queue.pop()

    def top(self) -> int:
        # 直接弹不需要判断为空的
        asn = self.pop()
        self.queue.append(asn)
        return asn

    def empty(self) -> bool:
        return  not self.queue


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值