31.栈的压入、弹出序列

题目:
输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序。

假设压入栈的所有数字均不相等。

例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。

注意:若两个序列长度不等则视为并不是一个栈的压入、弹出序列。若两个序列都为空,则视为是一个栈的压入、弹出序列。

思路:只需每次将栈顶元素跟弹出序列元素相比较,如果相同就弹出,不同就继续向栈内压入新元素。

class Solution {
public:
    bool isPopOrder(vector<int> pushV,vector<int> popV) {
        if (pushV.size() != popV.size()) return false;
        stack<int> stk;
        int i = 0;
        for (int j = 0; j < pushV.size();j++)
        {
            stk.push(pushV[j]);
            while(stk.size() && stk.top() == popV[i] )
            {
                stk.pop();
                i++;
            }
        }
        return stk.empty();
    }
};

一个需要注意的地方!
while(stk.size() && stk.top() == popV[i])这句代码中一定要先判断stk.size()不为空再判断stk.top() == popV[i]),如果颠倒顺序则会报错,虽然有&&操作,但应注意编译器执行的顺序!

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 01.平凡的忙碌 今天早上到学校门口的早餐店吃饭,进去的时候一个人都没有,我还纳闷这正饭点的怎么一个顾客都没有,后...
    宋一二阅读 3,512评论 9 18
  • statues:diet: meat. failed controlexercise: little conclu...
    欧阳去非阅读 164评论 0 0
  • 生命在于运动,此乃真知灼见,应奉为金科玉律,时时警戒自己。 减肥是当下的热门话题,也是很多人的人生主题。只有宣言没...
    舒然_ad6f阅读 220评论 0 0
  • 每个人运用自己的视觉、听觉、感觉器官,把外界的资料摄入头脑,因为不可能也不需要捕捉所有资料,所以感官运用总是对客观...
    方圆fg阅读 854评论 0 3