剑指offer:栈的压入弹出顺序

来源:互联网 发布:win10 64位安装mysql 编辑:程序博客网 时间:2024/06/04 18:38

题目描述

输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列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) {                stack<int> num;        int n =pushV.size();        if(popV.size()!=n)return false;        num.push(pushV[0]);        int j=1;        for(int i=0;i<n;i++){                       while(j<=n){                                if(num.top()==popV[i]){//弹出                    num.pop();                    break;                }                if(j==n)return false;//运行到这一步可以判断栈不可能为空                num.push(pushV[j]);                j++;            }                            }            return true;            }};



0 0
原创粉丝点击