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

栈的压入、弹出序列

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;
    }
};
全部评论

相关推荐

每晚夜里独自颤抖:你cet6就cet6,cet4就cet4,你写个cet证书等是什么意思。专业技能快赶上项目行数,你做的这2个项目哪里能提现你有这么多技能呢
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务