为什么栈的实现很多人写不出来

一 前言

本篇使用数组的方式实现栈,当然重点不在使用了什么样的数据结构去实现另一种数据结构,也可以使用动态数组,链表来实现栈;知识追寻者觉得比较重要的是实现一种数据结构的思路;比如栈,只要知道了如何去实现栈的思路,后面不就是敲敲几行代码的事情么,反之三思后行古人早就教给我们了;当然本文只提供一种简单的实现方式,肯定有许多不足之处;

二 栈的实现

2.1栈的含义

  • 栈是一种有序的线性表,只能在一端插入数据和删除数据,最后插入的数据也就是最先被删除的数据;通常栈也被称为先进后出或者后进先出的线性表结构;
  • 栈的定义看起来对初学者可能有点模糊,读者可以想象一下工厂里面的玻璃,一块一块玻璃从地面开始叠的高高的,取得时候是从最高层得一块玻璃往下取;
  • 看下面一张经典得栈结构图,中间是原本得栈大小为3,栈顶的数值为3;如果往栈顶加入一个数值4,就会变为左边的图,此时栈顶为4,栈大小为4;如果中间栈的删除一个元素,就会变为右边的图,此时栈顶值为2,栈大小为2;

2.2 栈的重要数据类型

通过前面说明介绍可以详细的认识到使用栈避不开,栈的栈顶值(top),栈的添加操作(push),栈的删除操作(pop),栈的当前大小(size);通常每种数据结构都有一个初始容量值(capacity),当栈的当前大小超出容量值,也就是溢栈,也就是很多文章里面很多提到的 stack overflow;

2.3 数组实现方式

  • 入栈push实现思路; 栈顶索引 + 1;
  • 出栈pop实现思路;栈顶索引-1;
  • 栈顶值peek就是栈顶索引;
/**
 * @Author lsc
 * <p>数组栈实现 </p>
 */
public class ArrayStack {

    // 容量
    private int capacity;
    // 数组栈
    private long[] stackArray;
    // 栈顶
    private int top;
    // 构造
    public ArrayStack(int size) {
        // 设置容量大小
        capacity = size;
        // 创建数组
        stackArray = new long[capacity];
        // 栈顶初始值为 -1 表示空栈
        top = -1;
    }
    // 入栈
    public void push(long data) {
        // 索引加1
        stackArray[++top] = data;
    }
    // 出栈
    public long pop() {
        // 索引减1
        return stackArray[top--];
    }
    // 栈顶值
    public long peek() {
        return stackArray[top];
    }
    // 判定是否是空栈
    public boolean isEmpty() {
        return (top == -1);
    }
    // 判定栈是否已满
    public boolean isFull() {
        return (top == capacity - 1);
    }

}

测试

public static void main(String[] args) {
        ArrayStack arrayStack = new ArrayStack(6);
        arrayStack.push(1);
        arrayStack.push(2);
        System.out.println(arrayStack.pop());
        System.out.println(arrayStack.peek());
        System.out.println(arrayStack.isEmpty());
        System.out.println(arrayStack.isFull());
    }

输出

2
1
false
false
posted @ 2020-03-21 10:21  知识追寻者  阅读(239)  评论(0编辑  收藏  举报