栈的压入、弹出序列

链接: 栈的压入、弹出序列
栈的压入、弹出序列_第1张图片

class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param pushV int整型vector 
     * @param popV int整型vector 
     * @return bool布尔型
     */
    bool IsPopOrder(vector<int>& pushV, vector<int>& popV) {
        size_t pushi = 0,popi = 0;//用来记录下标位置
        stack<int> _st;//用来模拟出栈

        while(pushi < pushV.size())
        {
            _st.push(pushV[pushi++]);
            //如果发现栈内元素和出栈数组有匹配的数字则进行出栈,如图
            while(!_st.empty() && _st.top() == popV[popi])
            {
                _st.pop();
                popi++;
            }
        }
        //如果最后两个数组下标相等,则说明出栈顺序是对的
        return pushi == popi;
    }
};

你可能感兴趣的:(c++,算法)