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

栈的压入、弹出序列

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

/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 *
 * @param pushV int整型一维数组
 * @param popV int整型一维数组
 * @return bool布尔型
 */
function IsPopOrder(pushV, popV) {
    if (pushV.length === 0 || popV.length === 0) return false;
    let stack = [];
    let popIndex = 0;
    for (let i = 0; i < pushV.length; i++) {
        stack.push(pushV[i]);
        while (stack.length > 0 && stack[stack.length - 1] === popV[popIndex]) {
            stack.pop();
            popIndex++;
        }
    }
    return stack.length===0
}
module.exports = {
    IsPopOrder: IsPopOrder,
};

可以按照第一个序列的压入顺序,模拟元素入栈的过程,并在每次入栈后,检查是否需要出栈。如果当前栈顶元素和第二个序列的当前元素相等,则出栈。最后,如果第一个序列中所有元素都已经入栈,并且栈为空(表示所有元素都成功出栈),那么第二个序列就是可能的弹出序列。

全部评论

相关推荐

1 收藏 评论
分享
牛客网
牛客企业服务