周三第八题  栈的压入、弹出序列 - Java

 AcWing打卡活动

《剑指Offer》打卡活动 

周三第八题  栈的压入、弹出序列

/**
 * 思路
 * 使用一个栈(stackV)依次压入pushV数组的值
 * 使用一个变量j记录弹出顺序
 * 在压入的过程中,如果该栈(stackV)的第一个元素等于popV[j],则弹出来(碰到之后必须弹出,不然后面将会没有机会弹出)
 * 计数器加一
 * 如果popV中的元素弹完,则表示符合
 * 
 * 
 */
class Solution {
    public boolean isPopOrder(int [] pushV,int [] popV) {
        // 参数校验 
        if(pushV.length <= 0 || popV.length <= 0 || pushV.length != popV.length) {
            return pushV.length <= 0 && popV.length <= 0;
        }

        Stack<Integer> stackV = new Stack();
        int j = 0; // popV计数器
        for(int i = 0; i < pushV.length; i++) {
            stackV.push(pushV[i]);
            // 如果值相等则准备弹出
            while(!stackV.empty() && stackV.peek() == popV[j]) {
                j++;
                stackV.pop();
                // popV中的元素弹完,符合弹出序列
                if(j == popV.length) {
                    return true;
                } 
            }
        }
        return false;
    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值