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

栈的压入、弹出序列

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

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param pushV int整型一维数组 
     * @param popV int整型一维数组 
     * @return bool布尔型
     */
    public boolean IsPopOrder (int[] pushV, int[] popV) {
        // write code here
        int n = pushV.length;//记录给一个数组的元素个数
        Stack<Integer> integer = new Stack<>();
        int j=0;
        for(int i=0;i<n;i++){//记录栈有多少元素被放入
            while(j<n&&(integer.isEmpty()||integer.peek()!=popV[i])){
			    //如果栈内已存在的元素等于n时 或者栈内是空的 或者栈顶的元素不等于出栈的数组
                integer.push(pushV[j]);//将元素放入栈内
                j++;
            }
            if(integer.peek()==popV[i]){//如果栈内的元素等于出栈数组的元素,那么就出栈
                integer.pop();
            }else{//否则就是无法出栈的
                return false;
            }
        }
        return true;
    }
}

全部评论

相关推荐

服从性笔试吗,发这么多笔,现在还在发。
蟑螂恶霸zZ:傻 x 公司,发两次笔试,两次部门匹配挂,
投递金山WPS等公司10个岗位 >
点赞 评论 收藏
分享
11-08 10:39
门头沟学院 C++
点赞 评论 收藏
分享
10-07 20:48
门头沟学院 Java
听说改名就会有offer:可能是实习上着班想到后面还要回学校给导师做牛马,看着身边都是21-25的年纪,突然emo了了
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务