[剑指Offer]栈的压入、弹出序列

本文首发于我的个人博客Suixin’s Blog
原文: https://suixinblog.cn/2019/03/target-offer-is-pop-order.html  作者: Suixin

题目描述

输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。(注意:这两个序列的长度是相等的)

解题思路

思路:使用一个辅助的栈,遍历压栈序列,依次压入辅助栈中,如果压入的元素与出栈序列首位元素相同,则连续出栈,直到不同为止,同时将出栈序列删除首位元素。入栈完毕后,如果出栈序列为空,则返回True,否则返回False

代码

Python(2.7.3)

# -*- coding:utf-8 -*-
class Solution:
    def IsPopOrder(self, pushV, popV):
        # write code here
        stack = []
        for i in pushV:
            stack.append(i)
            while popV:
                if popV[0] == stack[-1]:
                    popV.pop(0)
                    stack.pop()
                else:
                    break
        if not popV:
            return True
        else:
            return False

运行时间:46ms
占用内存:5840k

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容