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

2019-03-05  本文已影响0人  Sui_Xin

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

上一篇下一篇

猜你喜欢

热点阅读