剑指offer-栈的压入,弹出序列

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

难点坑点

  1. 我们先看class类中本题函数给定的传入参数是两个vector类型的序列,而这道题却是对栈的操作,我们可以通过创建stack类对象模拟入栈出栈操作,这样在后面的编程逻辑中会简化很多;
  2. 首先将入栈序列依次压入栈中,每次压入一个值就和出栈序列比较,当查找到当前出栈序列值后就不把本次值入栈的同时开始查找第二个出栈序列的值
  3. 注意使用stack1.top()函数的时候如果栈为空,会报错;
class Solution {
public:
    bool IsPopOrder(vector<int> pushV,vector<int> popV) {
        stack<int> stack1;
        int num=1;
        stack1.push(pushV[0]);
        for (int i=0;i<popV.size();i++)
        {
            while(stack1.top()!=popV[i]){
                if(num<pushV.size())
                    stack1.push(pushV[num++]);
                else
                    return false;
            }
            stack1.pop();
        }
        return true;
    }
};
    原文作者:YYming
    原文地址: https://www.jianshu.com/p/a1d17efc7ec5
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞