zoukankan      html  css  js  c++  java
  • 【剑指offer】31.栈的压入、弹出序列

    31.栈的压入、弹出序列

    面试题31. 栈的压入、弹出序列

    难度中等27

    输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如,序列
    {1,2,3,4,5} 是某栈的压栈序列,序列 {4,5,3,2,1} 是该压栈序列对应的一个弹出序列,但 {4,3,5,1,2}
    就不可能是该压栈序列的弹出序列。

    示例 1:

    输入:pushed = [1,2,3,4,5], popped = [4,5,3,2,1]
    输出:true
    解释:我们可以按以下顺序执行:
    push(1), push(2), push(3), push(4), pop() -> 4,
    push(5), pop() -> 5, pop() -> 3, pop() -> 2, pop() -> 1
    

    示例 2:

    输入:pushed = [1,2,3,4,5], popped = [4,3,5,1,2]
    输出:false
    解释:1 不能在 2 之前弹出。
    

    th:用栈模拟

    time:O(n)

    space:O(n)

       //用stack存储pushed的数据 poped pop 如果相等stack.pop
            public boolean validateStackSequences(int[] pushed, int[] popped) {
                Stack<Integer> stack = new Stack();
                int index = 0;
                //遍历pushed
                for(int i = 0,len = pushed.length ; i < len;i++){ 
                    stack.push(pushed[i]);
                    //如果pushed 和  popped 相等  stack pop
                    while(!stack.isEmpty() && index < len && stack.peek() == popped[index]){
                        stack.pop();
                        index++;
                    }
                }
                //如果栈为null 是 
                return stack.isEmpty();
            }
    
  • 相关阅读:
    (5)Linux权限管理
    paloalto防火墙版本升级
    paloalto防火墙安装内容和软件更新
    paloalto防火墙激活许可证和订阅
    paloalto防火墙注册
    paloalto防火墙执行初始配置
    paloalto防火墙的优势
    方位话机X2主、备用服务器问题
    心态
    paloalto防火墙接口使用方法及实例
  • 原文地址:https://www.cnblogs.com/qxlxi/p/12860639.html
Copyright © 2011-2022 走看看