首页 > 编程语言 > 详细

使用数组模拟实现栈

时间:2019-11-07 17:02:25      阅读:83      评论:0      收藏:0      [点我收藏+]

使用长度为5的数组模拟实现栈 先进后出的数据结构

package com.bjpowernode.test.datastructure;


 class MyStack {

    private Object [] datas;

    private int index;//只想下一个元素的引用或者下标

    public MyStack() {
        this.index = 0;
        datas= new Object[5];
    }


    /**
     * 压栈
     * @param obj
     */
    void push(Object obj) {
        int length = datas.length;
        if (index > length - 1) {
            //需要扩容或者抛异常
            throw new RuntimeException("栈已满");
        }
        datas[index] = obj;
        index++;
    }

    /**
     * 弹栈
     */
    Object pop() {
        if (index <= 0) {
            throw new RuntimeException("栈已空");
        }
        Object o = datas[index - 1];
        index--;
        return o;
    }
}
class TestStack {
    public static void main(String[] args) {
        MyStack myStack = new MyStack();
        myStack.push(1);
        myStack.push(1);
        myStack.push(1);
        myStack.push(1);
        myStack.push(1);
     //   myStack.push(1);
        System.out.println("=====");
        System.out.println(myStack.pop());
        System.out.println(myStack.pop());
        System.out.println(myStack.pop());
        System.out.println(myStack.pop());
        System.out.println(myStack.pop());
       // System.out.println(myStack.pop());

    }
}

 

使用数组模拟实现栈

原文:https://www.cnblogs.com/hkdpp/p/11813192.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!