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();
            }
    
  • 相关阅读:
    2、介绍在TensorFlow当中使用不同的方式创建张量tensor
    1、TensorFlow如何工作?
    1、
    7、Maven插件
    6、Maven仓库
    5、Maven-构建配置文件
    4、maven——构建生命周期
    3、示例(在java中使用JSON)
    2、json教程
    1、json背景
  • 原文地址:https://www.cnblogs.com/qxlxi/p/12860639.html
Copyright © 2011-2022 走看看