• 题目:

输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序。

如:假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列。

但4,3,5,1,2就不可能是该压栈序列的弹出序列。(注意:这两个序列的长度是相等的)

  • 解题思路:

建一个临时栈,将输入序列pushA[]的数据依次往栈中压,每进一个都跟popA[]中第一个位置的数比较,

若相同,则弹出,然后继续压入,同时跟popA[]第二个位置的数比较,若相同,则弹出,下一个压入的数和popA[]第三个位置的数比较,

依次进行下去,若到最后,临时栈内的数都能弹出,则说明,该popA[]是pushA[]的一个弹出序列,文字描述比较空洞,下面详细列举每个步骤的结果:

设有栈 Stack<Integer> temp = new Stack<Integer>();  弹出序列的下标int popIndex = 0;

pushA[] = {1,2,3,4,5};popA[] = {4,5,3,2,1};

(1)1压入,与 popA[popIndex]比较,1!=4;不弹出,继续压入;

(2)2压入,与 popA[popIndex]比较,2!=4;不弹出,继续压入;

(3)3压入,与 popA[popIndex]比较,3!=4;不弹出,继续压入;

(4)4压入,与 popA[popIndex]比较,4==4;4弹出,popIndex 后移一位,popIndex = popIndex + 1 = 1;   

(5)5压入,与 popA[popIndex]比较,5==5;5弹出,popIndex 后移一位,popIndex = popIndex + 1 = 2;   //五个数都依次进了栈

(6)5弹出后,栈顶元素为3,3与 popA[popIndex]比较,3==3;3弹出,popIndex 后移一位,popIndex = popIndex + 1 = 3;   

(7)3弹出后,栈顶元素为2,2与 popA[popIndex]比较,2==2;2弹出,popIndex 后移一位,popIndex = popIndex + 1 = 4;   

(8)2弹出后,栈顶元素为1,1与 popA[popIndex]比较,1==1;1弹出,popIndex 后移一位,popIndex = popIndex + 1 = 5;   

至此,临时栈内所有元素都弹出了,栈为空,则表明pupA[]是popA[]的一个弹出序列;

若popA [] = {4,5,3,1,2}; 则情况为:

(1)1压入,与 popA[popIndex]比较,1!=4;不弹出,继续压入;

(2)2压入,与 popA[popIndex]比较,2!=4;不弹出,继续压入;

(3)3压入,与 popA[popIndex]比较,3!=4;不弹出,继续压入;

(4)4压入,与 popA[popIndex]比较,4==4;4弹出,popIndex 后移一位,popIndex = popIndex + 1 = 1;   

(5)5压入,与 popA[popIndex]比较,5==5;5弹出,popIndex 后移一位,popIndex = popIndex + 1 = 2;   //五个数都依次进了栈

(6)5弹出后,栈顶元素为3,3与 popA[popIndex]比较,3==3;3弹出,popIndex 后移一位,popIndex = popIndex + 1 = 3;   

(7)3弹出后,栈顶元素为2,2与 popA[popIndex]比较,2!=1;2不弹出;2一直都不能弹出,所以该栈一直处于有数据的状态,则popA[]不是pushA[]的弹出序列;

  • 代码实现(Java):

/**
*
*/
package com.cherish.SwordRefersToOffer; import java.util.Stack; /**
* @author acer
*题目:
*输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序。
*假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列
*,但4,3,5,1,2就不可能是该压栈序列的弹出序列。(注意:这两个序列的长度是相等的)
*
*
*/
public class test_31_栈的压入和弹出序列 { /**
* @param args
*/
public static void main(String[] args) {
// TODO 自动生成的方法存根
int[] pushA = {1,2,3,4,5};
int[] popA = {4,5,3,2,1};
System.out.println(IsPopOrder(pushA,popA));
} public static boolean IsPopOrder(int [] pushA,int [] popA) {
if(pushA.length == 0||popA.length == 0)
{
return false;
}
Stack<Integer> temp = new Stack<Integer>();
//用于标识弹出序列的位置
int popIndex = 0;
for(int i = 0;i<pushA.length;i++)
{
temp.push(pushA[i]);
//如果栈不为空,且栈顶元素等于弹出序列
while(!temp.empty()&&temp.peek() == popA[popIndex])
{
//出栈
temp.pop();
//弹出序列向后一位
popIndex++;
}
}
return temp.empty();
} }

运行结果:

 

  • 代码实现(C#):

using System;
using System.Collections.Generic;
using System.Linq; namespace test_31_栈的压入和弹出序列
{
class Program
{
static void Main(string[] args)
{
int[] pushV = { , , , , };
int[] popV = { , , , , }; Console.WriteLine(IsPopOrder(pushV,popV));
Console.ReadLine();
} public static bool IsPopOrder(int[] pushV, int[] popV)
{
// write code here
if (pushV.Length == || popV.Length == )
{
return false;
}
var stack = new Stack<int>();
int popIndex = ;
for (int i = ; i < pushV.Length; i++)
{
stack.Push(pushV[i]);
while (stack.Count > && stack.Peek().Equals(popV[popIndex]))
{
stack.Pop();//弹出栈顶元素
popIndex++;//popV下标后移一位
}
}
return stack.Count() == ; }
}
}

实现结果:

 

剑指Offer_栈的压入序列是否有对应的弹出序列的更多相关文章

  1. 用js刷剑指offer(栈的压入、弹出序列)

    题目描述 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压 ...

  2. 剑指Offer 栈的压入、弹出序列

    题目描述 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序 ...

  3. 剑指offer——栈的压入、弹出序列

    题目:输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个栈是否为该栈的弹出顺序.假设压入栈的所有数字都不相等.例如序列1,2,3,4,5是某个栈的压入顺序,序列4,5,3,2,1是该栈序列的一 ...

  4. 剑指offer--28.栈的压入、弹出序列

    时间限制:1秒 空间限制:32768K 热度指数:300132 本题知识点: 栈 算法知识视频讲解 题目描述 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序.假 ...

  5. 剑指Offer-21.栈的压入、弹出序列(C++/Java)

    题目: 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈 ...

  6. 剑指offer - 栈的压入弹出序列 - JavaScript

    题目描述 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列 1,2,3,4,5 是某栈的压入顺序,序列 4,5,3,2,1 ...

  7. 剑指offer 栈的压入弹出 顺序

    判断: 如果下一个弹出的数字刚好是栈顶元素,那么直接弹出 如果下一个弹出的数字不在栈顶,我们要把压栈序列中,还没有入栈的数字压入辅助栈,知道把下一个需要弹出的数字压入栈顶 如果所有的数字都入栈,但是仍 ...

  8. 剑指offer 栈的压入和弹出

    题目描述输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈 ...

  9. 剑指Offer20 栈的压入弹出序列是否正确

    /************************************************************************* > File Name: 20_IsPopO ...

随机推荐

  1. Scrum冲刺第一篇

    一.各个成员在 Alpha 阶段认领的任务 负责人和协作者 任务内容 陈嘉欣 设计编码规范 邓镇港 UI设计 肖烈涛 数据库设计 林德泽 设计测试计划 余晓东 用户注册登陆验证模块 陈嘉欣 余晓东 林 ...

  2. LeetCode——Department Highest Salary(花式使用IN以及GROUP BY)

    The Employee table holds all employees. Every employee has an Id, a salary, and there is also a colu ...

  3. SqlServer数据库优化之添加主键和自增长

    今天需要给有500万条数据的表添加主键和自增长列,其中最大的难度在于如何UPDATE这500万多条数据,开始吧! 1.先给表添加一个字段叫ID,并允许空 2.查询表,我想到了使用其中的时间列排序来创建 ...

  4. Bert实战---情感分类

    1.情感分析语料预处理 使用酒店评论语料,正面评论和负面评论各5000条,用BERT参数这么大的模型, 训练会产生严重过拟合,,泛化能力差的情况, 这也是我们下面需要解决的问题; 2.sigmoid二 ...

  5. 笔记6:Django基础

    Django-MVT (1)查看python版本号: python -m django --version (2) 创建Django项目 django-admin startproject mysit ...

  6. mac os下切换pip3国内源并安装requests库

    在使用Python的时候,经常会用到pip来安装模块,但是默认的下载源实在是特别慢,经常install的时候还会因为速度的原因直接报错,因此我们可以选择将下载源更改为国内的,这样就可以提高我们的下载速 ...

  7. centos虚拟机 与主机同步时间

    同步系统时间: yum install ntp ntpdate cn.pool.ntp.org ntpdate 0.centos.pool.ntp.org rm /etc/localtime ln - ...

  8. zz 机器学习系统或者SysML&DL笔记

    机器学习系统或者SysML&DL笔记(一)  Oldpan  2019年5月12日  0条评论  971次阅读  1人点赞 在使用过TVM.TensorRT等优秀的机器学习编译优化系统以及Py ...

  9. JDOJ 1044 Span

    JDOJ 1044 Span https://neooj.com/oldoj/problem.php?id=1044 Description 某国有N个村子,M条道路,为了实现“村村通工程”现在要”油 ...

  10. biopython处理中蜂基因组

    1.安装包 pip install bcbio-gff pprint 2.显示中蜂的序列 from Bio import SeqIO genome_name = 'GCF_001442555.1_AC ...