美文网首页
[剑指Offer]栈的压入、弹出序列

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

作者: Sui_Xin | 来源:发表于2019-03-05 17:28 被阅读0次

    本文首发于我的个人博客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

    相关文章

      网友评论

          本文标题:[剑指Offer]栈的压入、弹出序列

          本文链接:https://www.haomeiwen.com/subject/apmouqtx.html