数据结构学习dayThree

* dayThree
* 栈
* 栈是限定仅在表位进行插入或删除操作的线性表。
* 表尾端称为栈顶(top);
* 表头端称为栈底(botto);
* 栈被称为后进先出的线性表(简称LIFO结构)。
* 和线性表类似,栈也有两种存储表示方法。
* 以下为顺序栈的实现。
* top为栈顶指针,每当插入新的栈顶元素时,指针top增1;
* 删除栈顶元素时,指针top减1。
* 非空栈中的栈顶指针始终在栈顶元素的下一个位置上。
/**
 * 栈的实现类
 */
public class Stack<E> {
    //栈顶指针
    private int top;

    //栈容量
    private int stackSize;

    private Object[] data;

    /**
     * 根据传入参数创建定长的栈
     * @param length 要创建的栈的长度
     */
    public Stack(int length) {
        if (length > 0) {
            data = new Object[length];
            top = -1;
            stackSize = length;
        } else {
            throw new RuntimeException("初始化大小不能小于0");
        }
    }

    /**
     * 栈判空
     * @return true为栈空,false为非空
     */
    public boolean isEmpty() {
        return top == -1;
    }

    /**
     * 栈判满
     * @return true为栈满,false为未满
     */
    public boolean isFull(){
        return stackSize - 1 == top;
    }

    /**
     * 元素进栈
     * @param e 要进栈的元素
     */
    public void push(E e){
        if (stackSize - 1 == top){
            throw new RuntimeException("栈已满,无法入栈。");
        }else {
            data[++top] = e;
        }
    }

    /**
     * 查看栈顶元素
     * @return 栈顶元素
     */
    public E getTop(){
        if (top == -1){
            throw new RuntimeException("栈空。");
        }else{
            return (E)data[top];
        }
    }

    /**
     * 弹出栈顶元素
     * @return 栈顶元素
     */
    public E pop(){
        if (top == -1){
            throw new RuntimeException("栈空。");
        }else{
            return (E)data[top--];
        }
    }
}

转载于:https://my.oschina.net/u/3970508/blog/3031962

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值