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