数据结构与算法:栈与队列

简介: 数据结构与算法:栈与队列

栈(Stack)


📌 什么是栈 ?

 栈也是一种线性数据结构.

 例如在一个死胡同里, 有5辆汽车(1~5)依次停放, 但当汽车需要倒出时我们发现, 最先进去的汽车1需要等待汽车5~汽车2依次倒出后才能出来;由此我们可以得出栈的特点先进后出(后进先出)

  这里的死胡同其实就相当于我们的栈,汽车就是需要操作的数据,将数据存放到栈中的过程称为入栈(也称压栈push),拿出的过程称为出栈(也称弹栈pop) .

 栈的底部成为栈底,顶部也就是操作数据的入口称为栈顶 .

注意我们操作数据是在栈顶处操作


🎀 创建Stack接口,并实现功能

public interface Stack<T> {
    //压栈
    void push(T ele);
    //弹栈
    T pop();
    //查找栈顶元素
    T peek();
    //是否为空
    boolean isEmpty();
    //栈中元素个数
    int getSize();
}

🎀 创建一个类,对接口中的抽象方法进行重写,将功能具体化

import com.learn.study1.MyArray;
 
public class Arraystack<T> implements Stack<T>{
 
    private MyArray<T> date;
    private int size;
 
    //构造函数(初始化)
    public Arraystack(){
        this.size = 0;
        this.date = new MyArray() ;
    }
 
    @Override
    public void push(T ele) {
        this.date.addTail(ele);
        this.size++;
    }
 
    @Override
    public T pop() {
        if (isEmpty()) {
            throw new IllegalArgumentException("stack is null");
        }
        T ele = this.date.removeTail();
        this.size--;
        return ele;
    }
 
    @Override
    public T peek() {
        if (isEmpty()) {
            throw new IllegalArgumentException("stack is null");
        }
        return this.date.getLastElement();
    }
 
    @Override
    public boolean isEmpty() {
        return this.size==0;
    }
 
    @Override
    public int getSize() {
        return this.size;
    }
    
    @Override
    public String toString() {
        return this.date.toString();
    }
}

✎ 队列(Queue)


📌 什么是队列 ?

• 队列就是排队,例如我们排队打饭,我们从对尾排队,打完饭后从对首离开。

特点:先进先出 FILO(只能从对尾进,对首出)


🎀 创建Queue接口,并实现功能    

public interface Queue<T> {
    //入队
    void offer(T ele);
    //出队
    T poll();
    //判断是否为空
    boolean isEmpty();
    //获取元素个数(长度)
    int getSize();
    //获取对首元素
    T getFront();
}

🎀 创建一个类,对接口中的抽象方法进行重写,将功能具体化                                                      

import com.learn.study1.MyArray;
 
public class ArrayQueue<T> implements Queue<T> {
    //数据容器
    private MyArray<T> date;
    //元素个数
    private int size;
 
    //初始化(构造方法)
    public ArrayQueue() {
        this.size = 0;
        this.date = new MyArray<>(20);
    }
 
    @Override
    public void offer(T ele) {//入队
        this.date.addTail(ele);
        this.size++;
    }
 
    @Override
    public T poll() {//出队
        if (isEmpty()) {
            throw new IllegalArgumentException("queue is empty!");
        }
        T res = this.date.getFirstElement();
        this.size--;
        return res;
    }
 
    @Override
    public boolean isEmpty() {
        return this.size == 0;
    }
 
    @Override
    public int getSize() {
        return this.size;
    }
 
    @Override
    public T getFront() {
        if (isEmpty()) {
            throw new IllegalArgumentException("queue is empty!");
        }
        return this.date.getFirstElement();
    }
}
相关文章
|
3天前
|
算法 安全 测试技术
golang 栈数据结构的实现和应用
本文详细介绍了“栈”这一数据结构的特点,并用Golang实现栈。栈是一种FILO(First In Last Out,即先进后出或后进先出)的数据结构。文章展示了如何用slice和链表来实现栈,并通过golang benchmark测试了二者的性能差异。此外,还提供了几个使用栈结构解决的实际算法问题示例,如有效的括号匹配等。
golang 栈数据结构的实现和应用
01_设计一个有getMin功能的栈
01_设计一个有getMin功能的栈
|
3天前
|
前端开发
07_用队列实现栈
07_用队列实现栈
06_用栈来求解汉诺塔问题
06_用栈来求解汉诺塔问题
05_用一个栈实现另一个栈的排序
05_用一个栈实现另一个栈的排序
03_如何仅用递归函数和栈操作逆序一个栈
03_如何仅用递归函数和栈操作逆序一个栈
|
3天前
|
测试技术
02_由两个栈组成的队列
02_由两个栈组成的队列
|
7天前
|
存储
|
5天前
|
安全 JavaScript 前端开发
栈溢出漏洞传播Worm.Delf.yqz
栈溢出漏洞传播Worm.Delf.yqz
|
4月前
|
算法 C++ Python
数据结构与算法===贪心算法
数据结构与算法===贪心算法
下一篇
无影云桌面