【剑指Offer】【栈】栈的压入、弹出序列
题目:输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。(注意:这两个序列的长度是相等的)
A:利用一个辅助栈,把第一个序列中的数字依次压入辅助栈中,再用循环比较栈顶元素和出栈序列是否相等
若循环最后,辅助栈空,则返回true
否则返回false
class Solution {
public:
    bool IsPopOrder(vector<int> pushV,vector<int> popV) {
        if(pushV.empty()|| pushV.size() != popV.size())
        {
            return false;
        }
        stack<int> m_stack;
        for(int i = 0,j = 0; i < pushV.size(); i++)
        {
            m_stack.push(pushV[i]);
            while(!m_stack.empty() && (popV[j] == m_stack.top()))
            {
                m_stack.pop();
                j++;
            }
        }
        if(m_stack.empty())
        {
            return true;
        }
        return false;
    }
};
  
相关题目:
最长公共子括号序列:https://www.nowcoder.com/practice/504ad6420b314e5bb614e1684ad46d4d
最小栈:实现一个最小栈,有三种操作,min:得到栈中的最小值,push:在栈顶插入一个元素,pop:弹出栈顶元素,使这三种操作的时间复杂度都是O(1) https://www.nowcoder.com/practice/a4d17eb2e9884359839f8ec559043761
获取n维数组的最大深度:输入参数为字符串型的n维数组,数组的每一项值为数组 或 int型数字。请实现一个函数,可以获取列表嵌套列表的最大深度为多少。
【剑指Offer】【栈】栈的压入、弹出序列的更多相关文章
- 剑指offer-面试题31-栈的压入弹出序列-栈
		#include<iostream> #include<string.h> #include<algorithm> #include<cmath> #i ... 
- 【剑指offer】栈的压入弹出序列,C++实现(举例)
		原创文章,转载请注明出处! 本题牛客网地址 博客文章索引地址 博客文章中代码的github地址 1.题目 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为第一个序列的出栈序列.注意 ... 
- 剑指offer - 栈的压入弹出序列 - JavaScript
		题目描述 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列 1,2,3,4,5 是某栈的压入顺序,序列 4,5,3,2,1 ... 
- 剑指offer-面试题22.栈的压入,弹出序列
		题目:输入两个整数序列,第一个序列表示栈的压入顺序,请判断第 二个序列是否为该栈的弹出顺序.假设压入栈的所有数字均不相等. 例如序列1.2.3.4.5是某栈的压栈序列,序列4.5.3.2.1 是该压栈 ... 
- 剑指offer系列19--栈的压入、弹出序列
		题目描述 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序 ... 
- 剑指offer-栈的压入弹出序列21
		题目描述 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压 ... 
- 剑指Offer20 栈的压入弹出序列是否正确
		/************************************************************************* > File Name: 20_IsPopO ... 
- 剑指Offer:栈的压入、弹出序列【31】
		剑指Offer:栈的压入.弹出序列[31] 题目描述 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列1,2,3,4,5是某栈 ... 
- Go语言实现:【剑指offer】栈的压入、弹出序列
		该题目来源于牛客网<剑指offer>专题. 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列1,2,3,4,5 ... 
- 剑指 Offer 31. 栈的压入、弹出序列 + 入栈顺序和出栈顺序的匹配问题
		剑指 Offer 31. 栈的压入.弹出序列 Offer_31 题目详情: 解析: 这里需要使用一个栈来模仿入栈操作. package com.walegarrett.offer; /** * @Au ... 
随机推荐
- Kali Win-KeX Win
			内容: 概述 用法 开始 启动根会话 会话管理 声音支持 多屏支持 停止 概述 窗口模式下的 Win-KeX 将在单独的窗口中运行 Kali Linux 桌面会话. 窗口模式有助于在视觉上将 Wind ... 
- 内网渗透-smb&wmi明文&hash传递
			首先我们要知道,在windows2012以上版本默认会关闭wdigest,那么攻击者就无法从内存中获取明文密码了 windows2012以下的版本如果安装了KB2871997补丁,那么同样也会导致无法 ... 
- (18)go-micro微服务ELK介绍
			目录 一 什么是ELK 二 Beats的六种工具 三 ELK系统的特点 四 ELK+beats系统架构 五 ELK优点 六 最后 一 什么是ELK ELK是三个[开源软件]的缩写,分别表示:Elast ... 
- .Net6 使用 Ocelot + Consul 看这篇就够了
			前言 卯兔敲门,新的一年,祝大家前'兔'似锦!希望大家假后还能找到公司的大门 O(∩_∩)O !书接上文,我们使用了 Consul实现了服务注册与发现,对Consul不熟悉的同学可以先看看.这篇文章我 ... 
- 四、流程控制和break、continue、range函数的讲解
			目录 一.流程控制理论和必备基础知识 理论: 必备基础知识: break.continue的用法: 二.流程控制之分支结构 if if...else if...elif...else if的嵌套使用 ... 
- drf-restful规范、django原生编写接口
			1.restful规范 REST全称是Representational State Transfer,中文意思是表述:表征性状态转移,它首次出现在2000年Roy Fielding的博士论文中.RES ... 
- 调用HttpClient.PostAsync时传token等值
			做内部接口转发时加token验证需要传token值过去,有如下两种方式 string jsonContent = JsonConvert.SerializeObject(args); using(va ... 
- Rpc-实现Zookeeper注册中心
			1.前言 本文章是笔主在声哥的手写RPC框架的学习下,对注册中心的一个拓展.因为声哥某些部分没有保留拓展性,所以本文章的项目与声哥的工程有部分区别,核心内容在Curator的注册发现与注销,思想看准即 ... 
- Kali Linux Web 渗透测试秘籍 中文版
			第一章 配置 Kali Linux 简介 在第一章中,我们会涉及如何准备我们的 Kali 以便能够遵循这本书中的秘籍,并使用虚拟机建立带有存在漏洞的 Web 应用的实验室. 1.1 升级和更新 Kal ... 
- 推荐一个分布式单点登录框架XXL-SSO!
			有关单点登录(SSO)之前有写过两篇文章 一文读懂 JWT! 看完这篇不能再说不懂SSO原理了! 如果说XXL-JOB你可能并不陌生,它是非常火爆的一个分布式任务调度平台.但其实在该作者还有一个非常优 ... 
