数据结构之栈

定义
栈(stack)又名堆栈,是一种特殊的线性表,因为其运算受限,仅能在一端进行插入(push)和删除(pop)操作。允许进行插入和删除的一端称为栈顶(top),另一端为栈底(bottom);栈底固定,栈顶浮动。最早插入的数据位于栈低,而最新插入的数据位于栈顶。
向一个栈插入数据被称为进栈、入栈或压栈,该操作会把数据放入栈顶元素的上面,使之成为新的栈顶;从一个栈删除元素又被称为出栈或退栈,该操作会把栈顶元素删除掉,使其相邻数据成为新的栈顶。

图示

特性
LIFO-last in first out,后进先出原则存储数据。

Java数组实现

点击查看代码
/**
 * 数组实现固定大小的栈,具有push()、pop()、peek()、isEmpty()和isFull()等方法。
 * @author Yoko
 */
@Data
@Slf4j
public class StackDemo {
    /** 栈大小 */
    private int maxSize;
    /** 容纳数据的数组 */
    private long[] stackArray;
    /** 栈顶 */
    private int top;
    public StackDemo(int maxSize) {
        this.maxSize = maxSize;
        this.stackArray = new long[maxSize];
        this.top = -1;
    }
    /** 是否满栈 */
    public boolean isFull() {
        return top == maxSize - 1;
    }
    /** 是否空栈 */
    public boolean isEmpty() {
        return top == -1;
    }
    /** 入栈 */
    public void push(long num) {
        boolean isFull = this.isFull();
        if (isFull) {
            log.error("栈已满,入栈失败。");
        }
        this.stackArray[++top] = num;
    }
    /** 出栈,删除数据 */
    public long pop() {
        boolean isEmpty = this.isEmpty();
        if (isEmpty) {
            log.info("栈已空,出栈失败。");
        }
        return this.stackArray[top--];
    }
    /** 出栈,删除数据 */
    public long peek() {
        return this.stackArray[top];
    }

    public static void main(String[] args) {
        // 创建容量为3的栈
        StackDemo stack = new StackDemo(3);
        // 入栈
        stack.push(5);
        stack.push(28);
        stack.push(3);
        // 查看栈顶
        log.info("入栈后查询栈顶, num = {}", stack.peek());
        // 出栈
        log.info("出栈, num = {}", stack.pop());
        // 查看栈顶
        log.info("出栈后查询栈顶, num = {}", stack.peek());
    }

}
posted @ 2021-12-29 10:19  梨猫南北  阅读(73)  评论(0编辑  收藏  举报