力扣946. 验证栈序列

这一题的思路和下面一题是一摸一一样的,都是模拟一个栈的过程。

PAT 1051 Pop Sequence

因此代码是简单的:

c++ 复制代码
class Solution {
public:
    int cut=0;
    stack<int> s;
    bool validateStackSequences(vector<int>& pushed, vector<int>& popped) {
      
       for(int i=0;i<popped.size();i++)
       {
             while(s.empty()||s.top()!=popped[i])
             {
                if(cut>=pushed.size())
                {
                    return false;
                }
                int x=pushed[cut];
                s.push(x);
                if(s.size()>popped.size())
                {
                    return false;
                }
                cut++;
              
             }
             s.pop();
       } 
       return true;
       



    }
};

我在写的时候出现了报错

出现了堆缓冲区溢出,访问 std::vector 时越界了。原因是我当时写的是

c++ 复制代码
if(cut>pushed.size())
{
   return false;
}

应该是

c++ 复制代码
if(cut>=pushed.size())
{
   return false;
}

因为cut是从0开始的,所以不能cut==pushed.size(),如果把cut=pushed.size(),让它push到栈中,就会出现访问越界。

以后写要注意啊

相关推荐
MicroTech202531 分钟前
微算法科技(MLGO)研发突破性低复杂度CFG算法,成功缓解边缘分裂学习中的掉队者问题
科技·学习·算法
墨染点香1 小时前
LeetCode 刷题【126. 单词接龙 II】
算法·leetcode·职场和发展
aloha_7891 小时前
力扣hot100做题整理91-100
数据结构·算法·leetcode
Tiny番茄2 小时前
31.下一个排列
数据结构·python·算法·leetcode
挂科是不可能出现的2 小时前
最长连续序列
数据结构·c++·算法
前端小L2 小时前
动态规划的“数学之魂”:从DP推演到质因数分解——巧解「只有两个键的键盘」
算法·动态规划
RTC老炮3 小时前
webrtc弱网-ReceiveSideCongestionController类源码分析及算法原理
网络·算法·webrtc
21号 13 小时前
9.Redis 集群(重在理解)
数据库·redis·算法
hadage2335 小时前
--- 数据结构 AVL树 ---
数据结构·算法
liu****5 小时前
8.list的使用
数据结构·c++·算法·list