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

栈的压入、弹出序列

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

这个题还是比较好理解,关键点在使用辅助栈。
题目最重要的信息是栈里的数据是唯一,这样在当前是否需要出栈的时候,可以用相等作为判断条件。
没有这个条件的化,栈里有很多相同的数,题目会很麻烦。需要回溯。

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


全部评论
最后返回时也应该判断j有没有走到头
点赞 回复 分享
发布于 2022-03-02 14:42

相关推荐

曲霜晨:娱乐至上的年代
点赞 评论 收藏
分享
评论
11
2
分享

创作者周榜

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