数据结构之数组下的栈

数组下的栈

特点:只能从栈顶添加元素,也只能从栈顶取出元素(后进先出)。

自定义栈接口

package com.company.stack;

/**
 * 自定义栈接口
 *  特点:先进后出
 * @param <T>
 */
public interface Stack<T> {

    // 获取栈长度
    int getSize();

    // 进栈操作
    void push(T ele) throws Exception;

    // 出栈操作
    T pop();

    // 查看栈顶元素
    T peek();

    // 判断栈是否为空
    boolean isEmpty();
}

自定义栈的实现类

package com.company.stack;

import com.company.array.Array;

/**
 * 自定义栈结构
 * 特点:只能从栈顶添加元素,也只能从栈顶取出元素(后进先出)
 *
 * @param <T> 泛型
 * @Author: wenhua
 * @CreateTime: 2023-01-07  07:43
 */
public class MyStack<T> implements Stack<T> {

    private Array<T> array;

    public MyStack() {
        this(10);// 调用有参构造函数
    }

    public MyStack(int capacity) {
        array = new Array<>(capacity);
    }

    /**
     * 判断栈是否为空
     *
     * @return
     */
    @Override
    public boolean isEmpty() {
        return array.isEmpty();
    }

    /**
     * 返回栈元素个数
     *
     * @return
     */
    @Override
    public int getSize() {
        return array.getSize();
    }

    /**
     * 进栈操作
     *
     * @param ele
     */
    @Override
    public void push(T ele) {
        try {
            array.addTail(ele);
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }

    /**
     * 出栈操作
     *
     * @return
     */
    @Override
    public T pop() {
        T result = null;
        try {
            result = array.removeTailElement();
        } catch (Exception e) {
            System.out.println("index is error");
        }
        return result;
    }

    /**
     * 查看栈顶元素
     *
     * @return
     */
    @Override
    public T peek() {
        T result = null;
        try {
            result = array.getElementByIndex(array.getSize() - 1);
        } catch (Exception e) {
            System.out.println("index is error");
        }
        return result;
    }

    @Override
    public String toString() {
        StringBuffer sbf = new StringBuffer();
        sbf.append("栈中总共有:" + getSize() + "个元素:");// '\n'表示换行
        sbf.append("[");

        try {
            for (int i = getSize() - 1; i >= 0; i--) {
                sbf.append(array.getElementByIndex(i));
                if (i != 0) {
                    sbf.append(",");
                }
            }
            sbf.append("]");
            return sbf.toString();
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }
}

main方法测试

package com.company.stack;

/**
 * @Author: wenhua
 * @CreateTime: 2023-01-07  07:58
 */
public class Main {
    public static void main(String[] args) {
        MyStack<String> stack = new MyStack<String>(2);
        stack.push("Jack");
        System.out.println("栈中元素个数为:" + stack.getSize());
        System.out.println("判断栈是否为空:" + stack.isEmpty());
        System.out.println("查看栈顶元素:" + stack.peek());
        stack.push("Jim");
        stack.push("wenhua");
        System.out.println(stack);
        while (!stack.isEmpty()) {
            System.out.println("pop出栈操作:" + stack.pop());
            System.out.println(stack);
            System.out.println("-------------");
        }
        System.out.println("判断栈是否为空:" + stack.isEmpty());
        // 栈为空,返回异常处理结果
        // System.out.println(myStack.pop()); 异常反馈 index is error 返回null
    }
}

添加完数据后,数组下的栈结构如下图:
在这里插入图片描述
运行结果

栈中元素个数为:1
判断栈是否为空:false
查看栈顶元素:Jack
栈中总共有:3个元素:[wenhua,Jim,Jack]
pop出栈操作:wenhua
栈中总共有:2个元素:[Jim,Jack]
-------------
pop出栈操作:Jim
栈中总共有:1个元素:[Jack]
-------------
pop出栈操作:Jack
栈中总共有:0个元素:[]
-------------
判断栈是否为空:true

注意:

栈在循环弹出时,长度是可变的,所以不能通过简单的for(int i = 0;i<stack.size();i++)来进行判断,只能通过while(!stack.isEmpty())或while(stack.size()!=0)来判断。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值