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

栈的压入、弹出序列

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

class Solution {
  public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param pushV int整型vector
     * @param popV int整型vector
     * @return bool布尔型
     */
    bool IsPopOrder(vector<int>& pushV, vector<int>& popV) {
        // write code here
        //1 用一个临时容器,进行模拟压入和弹出的情况
        vector<int> temp;
        //2 进行模拟压入和弹出
        int j = 0;
        int zhi = 0;
        for (j = 0, zhi = 0; zhi < pushV.size();zhi++) {
            if (pushV[zhi] !=
                    popV[j]) { //如果要压入不等于弹出的数据,进临时容器压入
                temp.push_back(pushV[zhi]);
            }
            else { 
                //如果要压入等于弹出的数据,先进行压入,然后用循环弹出尾部元素
                temp.push_back(pushV[zhi]);
                while(temp.back() == popV[j] && temp.size()>0){//这里利用栈的特性,一直访问尾部信息
                    temp.pop_back();//弹出尾部元素
                    j++;
                }
            }
        }
        if (j < pushV.size()) {
            return false;
        }
        else {
            return true;
        }
    }
};

全部评论

相关推荐

不愿透露姓名的神秘牛友
03-08 19:53
已编辑
AAA不喝拿铁:海投吧,感觉项目写的可以了,能cover住提问就行。我根据真实面经整理得到的最全(高/中/低频)面试题,适合面试前短期突击&长期提高补充,需要的牛u可以关注一手我的专栏,祝好运
点赞 评论 收藏
分享
bg&nbsp;为&nbsp;985&nbsp;本应届生,方向是嵌入式软件。纠结了很久,两边都不太了解,恳请各位大佬帮选,非常感谢🙏。
ResourceUtilization:求稳海能达,趁着年轻赚它一笔就relink吧,有个疑惑,怎么睿连同岗位多这么多base原因吗
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务