使用一维数组,模拟栈数据结构。(压栈,弹栈)

简介: 编写Java程序,使用一维数组,模拟栈数据结构。

编写Java程序


要求:
  1、这个栈可以存储java中的任何引用类型的数据。
  2、在栈中提供push方法模拟压栈。(栈满了,要有提示信息。)
  3、在栈中提供pop方法模拟弹栈。(栈空了,也有有提示信息。)
  4、编写测试程序,new栈对象,调用push pop方法来模拟压栈弹栈的动作。
  5.假设栈的默认初始化为10.
  public class MyStack{ // 栈类
    // 提供一个数组来存储栈中的元素
    Object[] elements;
    // 栈帧(永远指向栈顶部的元素)
    // 每加1个元素,栈帧+1
    // 每减1个元素,栈帧-1
    int index;
    // 构造方法
    // 构造方法是不是应该给一维数组一个初始化容量。
    // push方法(push方法压栈)
    // 压栈表示栈中多一个元素。
    // 但是栈如果已满,压栈失败。
    // 这个方法的参数以及返回值类型自己定义。
    // pop方法(pop方法弹栈)
    // 弹栈表示栈中少一个元素。
    // 但是栈如果已空,弹栈失败。
    // 这个方法的参数以及返回值类型自己定义。
  }


栈类:

// 栈类
public class MyStack {
    // 提供一个数组来存储栈中的元素
    private Object[] elements;
    //栈帧
    private int index;
    /*
        无参构造方法,初始化一维数组和栈帧。
     */
    public MyStack() {
        //默认初始化容量为10.(一维数组动态初始化。)
        this.elements = new Object[10];
        //初始化index
        this.index = -1;
    }
    /*
        压栈方法,ele为被压入的元素。
     */
    public void push(Object ele) {
        //栈帧指向数组最后一个元素的后面。
        if (index >= elements.length - 1) {
            System.out.println("对不起,压栈失败,栈已满");
            return;
        }
        //向栈中加一个元素,栈帧向上移动一个位置
        // index++;
        // this.elements[index]=ele;
        this.elements[++index] = ele;
        System.out.println("压栈" + ele + "成功,栈帧指向:" + index);
    }
    /*
        弹栈方法,从数组中弹出元素
     */
    public void pop() {
        if (index < 0) {
            System.out.println("弹栈失败,栈已空");
            return ;
        }
        //从栈中弹出一个元素,栈帧向下移动一位。
        //System.out.print("谈栈" + elements[index] + "成功");
        //index--
        System.out.print("谈栈" + elements[index--] + "成功");
        System.out.println("栈帧指向:"+index);
    }
    public Object[] getElements() {
        return elements;
    }
    public void setElements(Object[] elements) {
        this.elements = elements;
    }
}

测试类:

public class Text {
    public static void main(String[] args) {
        MyStack myStack=new MyStack();
       for(int i=0;i<10;i++) {
           myStack.push(i);
       }
        System.out.println("------------------------------------------------");
       for(int i=10;i>-1;i--){
           myStack.pop();
       }
    }
}


运行结果:

压栈0成功,栈帧指向:0
压栈1成功,栈帧指向:1
压栈2成功,栈帧指向:2
压栈3成功,栈帧指向:3
压栈4成功,栈帧指向:4
压栈5成功,栈帧指向:5
压栈6成功,栈帧指向:6
压栈7成功,栈帧指向:7
压栈8成功,栈帧指向:8
压栈9成功,栈帧指向:9
------------------------------------------------
谈栈9成功栈帧指向:8
谈栈8成功栈帧指向:7
谈栈7成功栈帧指向:6
谈栈6成功栈帧指向:5
谈栈5成功栈帧指向:4
谈栈4成功栈帧指向:3
谈栈3成功栈帧指向:2
谈栈2成功栈帧指向:1
谈栈1成功栈帧指向:0
谈栈0成功栈帧指向:-1
弹栈失败,栈已空
Process finished with exit code 0


相关文章
|
15天前
|
消息中间件 存储 搜索推荐
深入理解栈和队列(二):队列
深入理解栈和队列(二):队列
29 0
|
8天前
|
存储 算法 调度
数据结构期末复习(3)栈和队列
数据结构期末复习(3)栈和队列
16 0
|
20天前
|
存储 缓存 算法
【算法与数据结构】栈的实现详解
【算法与数据结构】栈的实现详解
|
20天前
|
存储 算法 编译器
【数据结构】栈算法(算法原理+源码)
【数据结构】栈算法(算法原理+源码)
【数据结构】栈算法(算法原理+源码)
|
24天前
|
存储
【数据结构】什么是栈?
【数据结构】什么是栈?
26 0
【数据结构】什么是栈?
|
27天前
|
存储 设计模式 算法
【C/C++ 数据结构 线性表】深入理解与实现栈:从基础到应用的全面探索
【C/C++ 数据结构 线性表】深入理解与实现栈:从基础到应用的全面探索
52 0
|
29天前
|
存储 算法 Serverless
【软件设计师备考 专题 】数据结构深度解析:从数组到图
【软件设计师备考 专题 】数据结构深度解析:从数组到图
56 0
|
29天前
|
机器学习/深度学习 存储 Java
揭秘数组:数据结构的基石与代码实践解析
揭秘数组:数据结构的基石与代码实践解析
9 0
|
1月前
【栈】数据结构栈的实现
【栈】数据结构栈的实现
|
1月前
|
存储
数据结构--栈和队列
数据结构--栈和队列

热门文章

最新文章