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

思路:如果下一个弹出的数字刚好是栈顶数字,那么直接弹出。如果下一个弹出的数字不在栈顶,我们把压栈序列中还没有入栈的数字压入辅助栈,直到把下一个需要弹出的数字压入栈顶为止。如果所有的数字,那么该序列不可能是一个弹出序列。
 
测试用例:
1)功能测试(输入的两个数组含有多个数字或者只有1个数字,第二个数组是或者不是第一个数组表示的压入序列对应的栈的弹出序列);
2)特殊输入测试(输入两个null指针)。
 
代码实现:
package com.yyq;

import java.util.Stack;

/**
* Created by Administrator on 2015/9/16.
*/
public class StackPushPopOrder {
public static boolean isPopOrder(int[] pPush, int[] pPop){
boolean bPossible = false;
if (pPop == null || pPush == null)
return bPossible;
int pslen = pPush.length;
int polen = pPop.length;
int i = 0;
int j = 0;
Stack<Integer> stackData = new Stack<>();
if (pPush != null && pPop != null && pslen == polen && pslen > 0){
while(i < polen){
while ((stackData.empty() || stackData.peek() != pPop[i]) && j < pslen){ //如果存在相同的数据那又怎么处理呢?
stackData.push(pPush[j]);
j++;
}
if (stackData.peek() != pPop[i])
break;
stackData.pop();
i++;
}
if (stackData.empty() && i == polen)
bPossible = true;
}
return bPossible;
} // ====================测试代码====================
public static void Test(String testName, int[] pPush, int[] pPop, boolean expected)
{
if(testName != null)
System.out.println(testName+" begins: ");
if(isPopOrder(pPush, pPop) == expected)
System.out.println("Passed.");
else
System.out.println("failed.");
System.out.println();
} public static void Test1()
{
int push[] = {1, 2, 3, 4, 5};
int pop[] = {4, 5, 3, 2, 1};
Test("Test1", push, pop, true);
} public static void Test2()
{
int push[] = {1, 2, 3, 4, 5};
int pop[] = {3, 5, 4, 2, 1};
Test("Test2", push, pop, true);
} public static void Test3()
{
int push[] = {1, 2, 3, 4, 5};
int pop[] = {4, 3, 5, 1, 2};
Test("Test3", push, pop, false);
} public static void Test4()
{
int push[] = {1, 2, 3, 4, 5};
int pop[] = {3, 5, 4, 1, 2}; Test("Test4", push, pop, false);
} // push和pop序列只有一个数字
public static void Test5()
{
int push[] = {1};
int pop[] = {2}; Test("Test5", push, pop, false);
} public static void Test6()
{
int push[] = {1};
int pop[] = {1}; Test("Test6", push, pop,true);
} public static void Test7()
{
Test("Test7", null, null, false);
} public static void main(String[] args){
Test1();
Test2();
Test3();
Test4();
Test5();
Test6();
Test7();
}
}
 
结果输出:
Test1 begins: 
Passed.
 
Test2 begins: 
Passed.
 
Test3 begins: 
Passed.
 
Test4 begins: 
Passed.
 
Test5 begins: 
Passed.
 
Test6 begins: 
Passed.
 
Test7 begins: 
Passed.

P134、面试题22:栈的压入、弹出序列的更多相关文章

  1. 剑指offer-面试题22.栈的压入,弹出序列

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

  2. 【剑指offer】栈的压入弹出序列,C++实现(举例)

    原创文章,转载请注明出处! 本题牛客网地址 博客文章索引地址 博客文章中代码的github地址 1.题目 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为第一个序列的出栈序列.注意 ...

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

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

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

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

  5. 剑指Offer:面试题22——栈的压入,弹出序列(java实现)

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

  6. 剑指 offer面试题22 栈的压入和弹出序列

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

  7. 剑指offer-栈的压入弹出序列21

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

  8. 《剑指offer》面试题22—栈的压入、弹出序列

    <程序员面试宝典>上也有经典的火车进站问题,类似. 如果12345是压栈顺序,序列45321可能是出栈顺序,但序列43512不可能. 规律:对序列中任意元素n,排在n后且比n小的元素一定是 ...

  9. 《剑指offer》面试题22 栈的压入、弹出序列 Java版

    (输入两个整数序列,第一个序列是一串数字的压入顺序,判断第二个序列是否是该栈数字的弹出顺序.) 我的方法:压入序列是给定的,每一次弹出操作形成一个弹出序列的值,我们从前往后遍历弹出序列,每一次访问弹出 ...

  10. 剑指offer-面试题31-栈的压入弹出序列-栈

    #include<iostream> #include<string.h> #include<algorithm> #include<cmath> #i ...

随机推荐

  1. java运算符新用法和^新认识

    public class Demo1 { public static void main(String[] args) { boolean t = false | true; System.out.p ...

  2. [摘抄] 为什么 Linq 可以高效率查询 SQL ?

    From C# in Depth(3rd) - Jon Skeet using (LinqDemoDataContext db = new LinqDemoDataContext()) { var f ...

  3. Qt移植 Window --Linux

    1.把源代码复制到Linux目录,使用qmake命令,注意在shell中直接使用qmake命令注意设置PATH环境变量 2. 在目录中会生成Makeflie文件 3. make即可 /usr/bin/ ...

  4. Skyline中使用AxTE3DWindowEx打开新的一个球体

    在winform窗体中拖入AxTE3DWindowEx控件. using system; using system.Collections.Generic; using System.Drawing; ...

  5. Winform ComboBox控件高亮显示

    //重绘下拉表单窗口,需要在窗口设计代码中加入下面这一句 this.cmdChannelName.DrawMode = System.Windows.Forms.DrawMode.OwnerDrawF ...

  6. centos架设FTP服务器

    1.安装vsftp在这里,我们架设的是虚拟用户,所谓虚拟用户就是没有使用真实的帐户,只是通过某种手段达到映射帐户和设置权限的目的.yum -y install vsftpd在CentOS中,这样就可以 ...

  7. Using jQuery to add a dynamic “Back To Top” floating button with smooth scroll

    Ever read a really long blog post or article and then had to scroll all the way up to the top of the ...

  8. 1064. Complete Binary Search Tree

    二叉排序树: http://www.patest.cn/contests/pat-a-practise/1064 #include <iostream> #include <vect ...

  9. 【Passport】微软过时的技术

    虽然已过时,没来得及体验,摘录一段别人的文章,假装对passport的了解 微软在过去的身份验证服务上,一直采用的Passport验证,但已经是N年前推出来的一个软件架构,当然也被软件界很多地方采用到 ...

  10. keystone命令与client接口学习

    keystone学习 ------------------ Keystone(OpenStack Identity Service)是OpenStack框架中,负责身份验证.服务规则和服务令牌的功能, ...