题解 | #栈的压入、弹出序列#

栈的压入、弹出序列

http://www.nowcoder.com/practice/d77d11405cc7470d82554cb392585106

class Solution {
public:
    bool IsPopOrder(vector<int> pushV,vector<int> popV) {
        int i=0,j=0;//一个指向pushV数组,一个指向popV数组
        stack<int >S;
        while(1){
            
            if(i==pushV.size()&&S.top()!=popV[j]){//此时直接返回false
                return false;
            }
            while(i<pushV.size()&&(S.empty()||S.top()!=popV[j])){//当栈为空或者栈顶元素不等于popV[j]时入栈
                S.push(pushV[i++]);
            }
            while(!S.empty()&&S.top()==popV[j]){
                S.pop();
                j++;
            }
            if(i==pushV.size()&&S.empty())
                return true;
        }
        return true;
    }
};
全部评论

相关推荐

我见java多妩媚:大外包
点赞 评论 收藏
分享
joe2333:怀念以前大家拿华为当保底的日子
点赞 评论 收藏
分享
评论
1
收藏
分享
牛客网
牛客企业服务