剑指 Offer 09. 用两个栈实现队列python

题目描述:

 题解:

两个栈底层还是采用队列实现,但需要使队列保持先进先出特性来模拟栈。

1.初始化两个栈stack1 stack2,stack1模拟队列,stack2辅助。

2.向队列末尾添加元素,可以直接使用append实现。

3.删除stack1头部元素实现方式:先将stack1中全部元素依次pop后添加到Stack2,此时stack2最顶端元素就是stack1的头部元素,用result记录stack2.pop()结果,然后再将stack2剩余元素依次放回stack1,保持stack1与原来相比只是少了头部元素。

class CQueue(object):

    def __init__(self):
        self.stack1 = []
        self.stack2 = []


    def appendTail(self, value):
        self.stack1.append(value)


    def deleteHead(self):
        if len(self.stack1)==0:
            return -1
        while self.stack1:
            self.stack2.append(self.stack1.pop())
        result = self.stack2.pop()
        while self.stack2:
            self.stack1.append(self.stack2.pop())
        return result

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值