剑指Offer、栈的压入、弹出序列

Problem: 946. 验证栈序列

入栈数组入栈,遇到弹出栈相同元素时弹出,最后判断栈是否为空。特判条件记得特判

Code

Java 复制代码
class Solution {
    public boolean validateStackSequences(int[] pushed, int[] popped) {
        if(pushed.length==0&&pushed.length==popped.length)return true;
        if(pushed.length!=popped.length)return false;
        Stack<Integer>stack=new Stack<>();
        for(int i=0,j=0;i<popped.length;i++)
        {
            while((stack.isEmpty()||popped[i]!=stack.peek())&&j<popped.length)
            {
                stack.push(pushed[j]);
                j++;
            }
            if(stack.peek()==popped[i])stack.pop();

        }
        if(!stack.isEmpty())return false;
        else return true;
    }
}
相关推荐
生成论实验室3 分钟前
用事件关系网络重新理解AI(二):损失函数、优化器与深度学习的动力学
数据结构·人工智能·深度学习·算法·语言模型
霍霍的袁9 分钟前
【C++初阶】缺省参数(默认参数)详细讲解
开发语言·c++·算法
risc12345611 分钟前
DocumentsWriterDeleteQueue 的核心设计思想
java·全文检索·lucene
计算机安禾15 分钟前
【算法分析与设计】第2篇:计算模型与渐进复杂性分析
算法
I Promise3418 分钟前
多传感器融合&模型后处理C++工程师面试参考回答
开发语言·c++·面试
生成论实验室21 分钟前
事件、信息荷与六维态势空间——每一个事件都是一次空间的弯曲
人工智能·算法·语言模型·可信计算技术·安全架构
budingxiaomoli25 分钟前
递归,搜索与回溯算法--递归
算法
风味蘑菇干26 分钟前
Stream基础题目
java·算法
2501_9327502629 分钟前
Java反射机制基础入门
java·开发语言
5008437 分钟前
HCCL 集合通信编程:多卡协同的正确姿势
java·flutter·性能优化·electron·wpf