【C++算法】69.栈_验证栈序列

文章目录


题目链接:

946. 验证栈序列


题目描述:


解法

直接用栈来验证栈序列。


C++ 算法代码:

cpp 复制代码
class Solution 
{
public:
    bool validateStackSequences(vector<int>& pushed, vector<int>& popped) 
    {
        // 验证栈序列算法
        // 基本思路:模拟栈的操作,看是否能够按照给定的顺序实现出栈
        
        stack<int> st;        // 用栈来模拟入栈和出栈操作
        int i = 0;            // 当前处理的popped数组的索引
        int n = popped.size(); // popped数组的长度
        
        // 遍历pushed数组中的每个元素
        for(auto x : pushed)
        {
            st.push(x);  // 将当前元素入栈
            
            // 尝试执行出栈操作:只要栈顶元素等于当前需要出栈的元素,就执行出栈
            while(st.size() && st.top() == popped[i])
            {
                st.pop();  // 弹出栈顶元素
                i++;       // 移动到popped数组的下一个元素
            }
        }
        
        // 如果所有元素都能正确出栈,则i应该等于n
        return i == n;
    }
};
相关推荐
Mr.Jessy3 小时前
JavaScript高级:构造函数与原型
开发语言·前端·javascript·学习·ecmascript
云栖梦泽5 小时前
鸿蒙应用签名与上架全流程:从开发完成到用户手中
开发语言·鸿蒙系统
爱上妖精的尾巴5 小时前
6-4 WPS JS宏 不重复随机取值应用
开发语言·前端·javascript
fie88897 小时前
NSCT(非下采样轮廓波变换)的分解和重建程序
算法
小鸡吃米…7 小时前
Python 列表
开发语言·python
kaikaile19957 小时前
基于C#实现一维码和二维码打印程序
开发语言·c#
晨晖27 小时前
单链表逆转,c语言
c语言·数据结构·算法
我不是程序猿儿8 小时前
【C#】画图控件的FormsPlot中的Refresh功能调用消耗时间不一致缘由
开发语言·c#
rit84324998 小时前
C# Socket 聊天室(含文件传输)
服务器·开发语言·c#
kk哥88998 小时前
C++ 对象 核心介绍
java·jvm·c++