输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。(注意:这两个序列的长度是相等的)
第一个序列表示栈的压入顺序,第一个序列并不是代表一个固定的栈,按第一个序列的顺序入栈,但是在入栈的同时有可能也有出栈的操作。同样第二个栈代表出栈的顺序,但是入栈和出栈是如何交替进行的并不知道。
# -*- coding:utf-8 -*-
class Solution:
def IsPopOrder(self, pushV, popV):
# write code here
if len(popV) == 0 or len(pushV) != len(popV):
return False
# stackData是模拟实际栈的状态
stackData = []
for i in pushV:
stackData.append(i)
# 如果i出栈之后一直在出栈,就POP所有的相等的元素
while len(stackData) and stackData[-1] == popV[0]:
stackData.pop()
popV.pop(0)
# 如果stackData[-1] != popV[0],说明现在没有出栈的操作
# 继续按顺序入栈
# 如果两个序列是匹配的,入栈的元素按照对应的出栈方式出栈
# 最后栈里应该是空的
if len(stackData):
return False
return True