当前位置: 首页 > news >正文

经典问题——验证栈序列

我们先来看题目描述:

给定 pushed 和 popped 两个序列,每个序列中的值都不重复,只有当它们可能是在最初空栈上进行的推入 push 和弹出 pop 操作序列的结果时,返回 true ;否则,返回 false 。

示例 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 之前弹出。

提示:

1 <= pushed.length <= 1000 0 <= pushed[i] <= 1000 pushed 的所有元素互不相同 popped.length == pushed.length popped 是 pushed 的一个排列。

解析:

只要模拟入栈和出栈的过程,将一个数进行入栈操作的时候检查该数是否为下一个要出栈的数,如果是就弹出该数,并继续检查栈中的数。如果能扫描完所有要出栈的数,就是一个合法的栈序列。

Java 代码实现:(使用 ArrayList 模拟栈)

class Solution { public boolean validateStackSequences(int[] pushed, int[] popped) { List<Integer> S=new ArrayList<>(); int j=0; for(int i=0;i<pushed.length;i++){ S.add(pushed[i]); while(S.size()>0&&j<popped.length&&S.get(S.size()-1)==popped[j]){ S.remove(S.size()-1); j++; } } return j==popped.length; } }

C++ 代码实现:(直接用 STL stack )

class Solution { public: bool validateStackSequences(vector<int>& pushed, vector<int>& popped) { stack<int>S; int n=pushed.size(); int j=0; for(int i=0;i<n;i++){ S.push(pushed[i]); while(S.size()>0&&j<n&&S.top()==popped[j]){ S.pop(); j++; } } return j==n; } };
http://www.rkmt.cn/news/1520936.html

相关文章:

  • STM32 HAL库驱动TB6612模块:精准控制编码电机转速与转向(附CubeMX配置)
  • 2026年消防培训学校怎么选?行业现状、机构分析及就业趋势解读 - 优质品牌商家
  • 2026年近期湖南GRC翘脚优质厂家选型指南 - 品牌鉴赏官2026
  • 免费解锁Adobe全家桶:开源破解工具Adobe-GenP 3.0终极指南
  • STM32F103驱动2.8寸TFT屏:FSMC硬核加速与GPIO软件模拟,哪个更适合你的项目?
  • 2026年成都训犬学校怎么选?六家机构实地调研与口碑分析 - 优质品牌商家
  • 别再乱选TVS管了!手把手教你根据USB、UART、电池接口选对ESD型号(附具体型号清单)
  • DOTA数据集标注选HBB还是OBB?从实际项目角度聊聊选择策略与坑点
  • 2026年6月市场技术好的喷泉制造公司推荐分析,程控喷泉/呐喊喷泉/音乐喷泉/旱式喷泉/潮汐瀑布,喷泉安装厂家哪个好 - 品牌推荐师
  • 从‘炼丹’到‘推理服务’:如何用消费级显卡(如RTX 4090)低成本部署LLaMA-2 70B模型
  • 量子近似优化算法与动态李代数在组合优化中的应用
  • 国内一体化污水处理设备源头厂家实力排行盘点:养殖污水处理设备/动物粪便脱水机/医院污水处理设备/优选指南 - 优质品牌商家
  • 企业级AI Agent实施方法论:从需求分析到上线运维的全生命周期
  • 手把手教你:在HarmonyOS开发板小凌派RK2206上跑通TinyMaix手写数字识别
  • 2026年宁波家电维修市场观察:日本进口电饭煲维修与全品类服务深度解析 - 优质品牌商家
  • 告别重建账套!金蝶K3 WISE“瘦身”新思路:用工具+SQL实现历史数据精准清理
  • VisionMaster N点标定避坑大全:从‘相机静止’到‘相机运动’模式,你的误差可能就藏在这些参数里
  • 单总线电路选二极管还是MOS管?一个真实电池供电项目的踩坑实录与最终选择
  • 告别VNC卡顿:3种高效远程开发Jetson Nano的方案实测(SSH/VSCode/CLion)
  • ISO121x芯片Layout避坑指南:从数据手册到四层板,搞定±70kV/µs CMTI的PCB设计
  • Windows安卓应用安装器:5分钟实现手机游戏在电脑上流畅运行
  • 读懂一篇英文论文到底在看什么?从标题、摘要到讨论的保姆级拆解指南
  • 别再只调参了!给ResNet50加上SENet/CBAM/ECA注意力,猫狗分类实战对比(附完整PyTorch代码)
  • Wi-Fi 7路由器BE33000/21000/16000/10000命名背后的秘密:高通Networking Pro平台全解析
  • 别再只用官方脚本了!用calflops库为你的mmdetection模型精准计算FLOPs和Params(附避坑指南)
  • 从Word Embedding到Transformer:5种深度学习文本表示方法在聚类中的效果对比
  • 从ICPC武汉邀请赛B题看位运算优化:如何用二分和枚举把‘或’运算结果压到最低?
  • 别再傻傻分不清了!点积、叉积、内积、外积,用Python代码和几何动画一次讲透
  • 告别Vuex/Pinia依赖:用mitt在Vue 3里轻松搞定跨组件通信(附完整示例)
  • 从8分钱MCU到遥控小车:普冉PY32F0系列实战选型指南(附资源对比)