数据结构与算法入门——线性结构之栈、队列

        栈(stack)又名堆栈,它是一种运算受限的线性表。限定仅在表尾进行插入和删除操作的线性表。它包括栈顶和栈底。向栈中添加一个元素称为进栈、入栈或压栈,从一个栈删除元素又称作出栈或退栈。有趣的是它的元素管理方式是“先进后出”,即最先入栈的一个元素,却是最后一个出栈。就好比压手枪弹夹,第一颗被压入的子弹在弹夹底部,等到最后一枪才能打出第一颗子弹。

在这里插入图片描述

public class StackUtil {
    //创建一个新数组
    private int[] arr;
    //构造方法
    public StackUtil(){
        arr = new int[0];
    }

    //入栈方法:就是之前数组的添加元素的方法
    public void add(int element){
        //创建一个新数组
        int[] newArr = new int[arr.length+1];
        //将旧数组中的元素复制到新数组中
        for (int i = 0; i <arr.length ; i++) {
            newArr[i] = arr[i];
        }
        //将目标元素放入到新数组的最后一位
        newArr[newArr.length-1] = element;
        //用新数组替换掉旧数组
        arr=newArr;
    }

    //出栈方法:也相当于之前数组删除元素的方法,但是返回值是取出的栈顶元素
    public int pop(){
        //如果栈中没有元素,则抛出异常
        if (arr.length==0){
            throw new RuntimeException("栈为空");
        }
        //取出旧数组中最后一个元素,即栈顶元素
        int element = arr[arr.length-1];
        //新建一个数组
        int[] newArr = new int[arr.length-1];
        for (int i = 0; i <newArr.length ; i++) {
            newArr[i] = arr[i];
        }
        arr = newArr;
        return element;
    }
    //打印数组
    public void show(){
        System.out.println(Arrays.toString(arr));
    }
    //查看栈顶元素
    public int peek(){
        return arr[arr.length-1];
    }
    //判断栈是否为空
    public boolean isEmpty(){
        return arr.length == 0;
    }

}
        队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表。进行插入操作的端称为队尾,进行删除操作的端称为队头。队列与栈正好是相反的,他是“先进先出”,就好比火车站进站排队,第一个进去的乘客当然是第一个出来,所以代码与栈几乎差不多

在这里插入图片描述

public class QueueUtil {
    //创建一个新数组
    private int[] arr;
    //构造方法
    public QueueUtil(){
        arr = new int[0];
    }

    //插入方法:就是之前数组的添加元素的方法
    public void add(int element){
        //创建一个新数组
        int[] newArr = new int[arr.length+1];
        //将旧数组中的元素复制到新数组中
        for (int i = 0; i <arr.length ; i++) {
            newArr[i] = arr[i];
        }
        //将目标元素放入到新数组的最后一位
        newArr[newArr.length-1] = element;
        //用新数组替换掉旧数组
        arr=newArr;
    }

    //删除方法:也相当于之前数组删除元素的方法,但是返回值是取出的队头元素
    public int pop(){
        //如果栈中没有元素,则抛出异常
        if (arr.length==0){
            throw new RuntimeException("栈为空");
        }
        //取出旧数组中第一个元素,即队头元素
        int element = arr[0];
        //新建一个数组
        int[] newArr = new int[arr.length-1];
        for (int i = 0; i <newArr.length ; i++) {
            newArr[i] = arr[i+1];
        }
        arr = newArr;
        return element;
    }
    //打印数组
    public void show(){
        System.out.println(Arrays.toString(arr));
    }
    //查看队头元素
    public int peek(){
        return arr[0];
    }
    //判断队列是否为空
    public boolean isEmpty(){
        return arr.length == 0;
    }
}
发布了7 篇原创文章 · 获赞 1 · 访问量 156

猜你喜欢

转载自blog.csdn.net/qq_40181435/article/details/104460873