Java实现顺序栈原理解析

 更新时间:2019年11月15日 10:43:40   作者:梦小冷  
这篇文章主要介绍了Java实现顺序栈原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

这篇文章主要介绍了Java实现顺序栈原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

什么是栈

1.栈的英文是stack

2.栈是一个先入后出的有序列表

3.栈是限制线性表元素的插入和删除只能在线性表的同一端进行的一种特殊的线性表,允许插入和删除的一端是,为变化的一端,成为栈顶,另外的一端为固定的一端为栈底

4.栈的定义可知,最先放入栈中的元素在栈底,最后放入的元素在栈顶,而删除的情况刚好相反,最后放入的元素先删除,最先放入的元素后删除

栈的应用场景

1.子程序的调用,在跳向子程序之前会先将下一条指令的地址存放在堆栈中,直到子程序执行后再将地址取出,最后回到原来的程序之中

2.递归的调用,和子程序的调用类似,只是出了存储下一个指令的地址外,也将参数、区域变量、等数据压入栈中

3.表达式的转换与求值

4.二叉树的遍历

5.图形的深度优先搜索

代码


package stack;

public class ArrayStack {
  private int maxSize;//最大值
  private int[] stack;//栈
  private int top=-1;//栈顶
  
  //构造器
  public ArrayStack(int maxSize) {
    this.maxSize=maxSize;
    stack=new int[this.maxSize];
  }
  
  //栈满
  public boolean isFull() {
    return top==maxSize-1;
  }
  
  //栈空  
  public boolean isEmpty() {
    return top==-1;
  }
  
  //入栈-push
  public void push(int value) {
    //先判断是否栈满了
    if(isFull()) {
      System.out.println("栈已经满了~");
      return;
    }else {
      top++;
      stack[top]=value;
    }
  }
  
  //出栈-pop
  public int pop() {
    if(isEmpty()) {
      throw new RuntimeException("栈已经空了~");
    }
    int value=stack[top];
    top--;
    return value;
  }
  
  //遍历栈
  
  public void list() {
    if(isEmpty()) {
      System.out.println("栈空,没有数据~");
    }
    for(int i=top;i>=0;i--) {
      System.out.printf("stack[%d]=%d\n",i,stack[i]);
    }
  }
}

测试类

package stack;

import java.util.Scanner;

public class TestArrayList {

  public static void main(String[] args) {
    // TODO Auto-generated method stub
    ArrayStack stack=new ArrayStack(4);
    String key="";
    boolean loop=true;
    Scanner scanner=new Scanner(System.in);
    while(loop) {
      System.out.println("show:显示栈");
      System.out.println("exit:退出测试");
      System.out.println("push:压栈");
      System.out.println("pop:出栈");
      System.out.println("请输入你的选择:");
      key=scanner.next();
      switch (key) {
      case "show":
        stack.list();
        break;
      case "push":
        System.out.println("请输入一个数:");
        int value=scanner.nextInt();
        stack.push(value);
        break;
      case "pop":
        try {
          int res=stack.pop();
          System.out.printf("出栈的元素为:%d\n",res);
        } catch (Exception e) {
          // TODO: handle exception
          System.out.println(e.getMessage());
        }
        break;
      case "exit":
        scanner.close();
        loop=false;
        break;

      default:
        break;
      }
    }
    System.out.println("程序退出!");
  }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

您可能感兴趣的文章:

相关文章

  • JSON序列化Redis读取出错问题解决方案

    JSON序列化Redis读取出错问题解决方案

    这篇文章主要介绍了JSON序列化Redis读取出错问题解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • 利用Java中Calendar计算两个日期之间的天数和周数

    利用Java中Calendar计算两个日期之间的天数和周数

    Java 语言的Calendar(日历),Date(日期),和DateFormat(日期格式)组成了Java标准的一个基本但是非常重要的部分。日期是商业逻辑计算一个关键的部分。下面这篇文章就给大家介绍了如何利用Java中Calendar计算两个日期之间的天数和周数,下面来一起看看吧。
    2016-12-12
  • GSON实现Java对象与JSON格式对象相互转换的完全教程

    GSON实现Java对象与JSON格式对象相互转换的完全教程

    GSON是Google编写并在在GitHub上开源的Java序列化与反序列化JSON的类库,今天我们就来总结一下使用GSON实现Java对象与JSON格式对象相互转换的完全教程
    2016-06-06
  • Java并发编程信号量Semapher

    Java并发编程信号量Semapher

    这篇文章主要介绍了Java并发编程信号量Semapher,Semapher信号量也是Java中的一个同步器,下文关于信号量Semapher的更多内容介绍,需要的小伙伴可以参考下面文章
    2022-04-04
  • Java反射机制的精髓讲解

    Java反射机制的精髓讲解

    今天小编就为大家分享一篇关于Java反射机制的讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • SpringBoot项目实用功能之实现自定义参数解析器

    SpringBoot项目实用功能之实现自定义参数解析器

    这篇文章主要介绍了SpringBoot项目实用功能之实现自定义参数解析器,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08
  • Java如何获取相对路径文件

    Java如何获取相对路径文件

    这篇文章主要介绍了Java如何获取相对路径文件问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06
  • Java Clone(类的复制)实例代码

    Java Clone(类的复制)实例代码

    Java Clone(类的复制)实例代码,需要的朋友可以参考一下
    2013-03-03
  • Java编程在方法中哪些时候需要参数

    Java编程在方法中哪些时候需要参数

    这篇文章主要介绍了Java编程在方法中哪些时候需要参数,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-02-02
  • 详解JAVA Timer和TimerTask

    详解JAVA Timer和TimerTask

    这篇文章主要介绍了JAVA Timer和TimerTask的相关资料,文中讲解非常细致,代码帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-07-07

最新评论