【剑指offr--C/C++】JZ31 栈的压入、弹出序列

一、题目

二、思路及代码

借助一个辅助栈来模拟入栈过程,

①在入栈之前先判断当前要入栈的元素是否与出栈数组当前元素相同,

② 如果不相同就入栈;

③如果相同就不用入栈了(不入栈=出栈),然后再依次取出栈的栈顶元素看是否与出栈数组当前值相同,相同的话就依次出栈,知道不再相等或者全部出栈;

④若入栈元素还没有遍历完,就继续重复前三个步骤

cpp 复制代码
class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param pushV int整型vector 
     * @param popV int整型vector 
     * @return bool布尔型
     */
    bool IsPopOrder(vector<int>& pushV, vector<int>& popV) {
        // write code here
        int i=0;
        int j=0;
        for(i,j;i<pushV.size(),j<popV.size();){
            //相同就不入栈
            if(pushV[i]==popV[j]){
                
                j++;
                //遍历栈顶元素,若与出栈元素相同就出栈
                while(j<popV.size()&&!st.empty() && st.top()==popV[j]){
                    j++;
                    st.pop();
                }
            }else{
                //不相同就入栈
                st.push(pushV[i]);
                
            }
            //每处理完一个入栈数组元素就+1
            i++;
        }
        if(st.empty()) return true;
        return false;

    }

    private:
    stack<int>st;
};
相关推荐
海兰9 分钟前
ES9.x 银行场景:银行卡可疑交易风控工作流示例
java·elasticsearch·搜索引擎
Drifter_yh26 分钟前
「JVM」 深入剖析 JVM 内存结构:从底层原理到线上排查
java·jvm
Once_day37 分钟前
C++之《程序员自我修养》读书总结(4)
c语言·c++·编译和链接
莫寒清1 小时前
Java 线程池详解
java·面试
三无少女指南1 小时前
开发者环境配置:用 Ollama 实现本地大模型部署(附下载慢的解决方案
c语言·开发语言·数据库·ubuntu
廋到被风吹走1 小时前
安全防护深度解析:敏感信息加密、密码哈希与密钥管理实战
java
2501_918126912 小时前
stm32核心板是什么属性?
linux·c语言·stm32·嵌入式硬件·个人开发
biyezuopinvip2 小时前
基于Spring Boot的投资理财系统设计与实现(毕业论文)
java·spring boot·vue·毕业设计·论文·毕业论文·投资理财系统设计与实现
iAkuya2 小时前
(leetcode)力扣100 75前K个高频元素(堆)
java·算法·leetcode
极客先躯2 小时前
高级java每日一道面试题-2025年7月17日-基础篇[LangChain4j]-如何实现模型的负载均衡和故障转移?
java·langchain·负载均衡·重试机制·负载均衡实现·故障转移实现·多级降级