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

查看12道真题和解析