美文网首页
数据结构与算法(第一季):队列

数据结构与算法(第一季):队列

作者: 萧1帅 | 来源:发表于2021-11-03 09:14 被阅读0次

一、队列

  • 队列是一种特殊的线性表, 只能在头尾两端操作
  • 队尾(rear): 只能从队尾添加元素, 一般叫做enQueue, 入队
  • 对头(front): 只能从对头移除元素, 一般叫做deQueue, 出队
image

<figcaption></figcaption>

二、接口设计

int size();
boolean isEmpty();
void clear();
void enQueue(E element);
E deQueue();
E fornt();
复制代码
  • 队列的内部实现可以用动态数组链表实现, 链表优先使用双向链表

三、队列实现

public class Queue<E> {
    private LinkedList<E> list;

    public Queue() {
        list = new LinkedList<>();
    }

    public int size() {
        return list.size();
    }
    public boolean isEmpty() {
        return list.isEmpty();
    }
    public void clear() {
        list.clear();
    }
    public void enQueue(E element) {
        list.add(element);
    }
    public E deQueue() {
        return list.remove(0);
    }
    public E fornt() {
        return list.get(0);
    }
}
复制代码

四、双端队列

  • 双端队列是能在头尾两端添加删除的队列

1、接口设计

// 元素的数量
int size();
// 是否为空
boolean isEmpty();
// 清空
void clear();
// 从队尾入队
void enQueueRear(E element);
// 从对头出队
E deQueueFront();
// 从对头入队
void enQueueFront(E element);
// 从队尾出队
E deQueueRear();
// 获取队列的头元素
E fornt();
// 获取队列的尾元素
E rear();
复制代码

2、双端队列实现

public class Deque<E> {
    private LinkedList<E> list;

    public Deque() {
        list = new LinkedList<>();
    }

    // 元素的数量
    int size() {
        return list.size();
    }
    // 是否为空
    boolean isEmpty() {
        return list.isEmpty();
    }
    // 清空
    void clear() {
        list.clear();
    }
    // 从队尾入队
    void enQueueRear(E element) {
        list.add(element);
    }
    // 从对头出队
    E deQueueFront() {
        return list.remove(0);
    }
    // 从对头入队
    void enQueueFront(E element) {
        list.add(0, element);
    }
    // 从队尾出队
    E deQueueRear() {
        return list.remove(list.size() - 1);
    }
    // 获取队列的头元素
    E fornt() {
        return list.get(0);
    }
    // 获取队列的尾元素
    E rear() {
        return list.get(list.size() - 1);
    }
}
复制代码

五、循环队列

  • 队列内部实现也可以用动态数组实现, 并且将各项接口优化到O(1)的时间复杂度, 这个用数组实现并优化之后的队列就叫做: 循环队列
  • 使用一个索引变量front控制第0个元素所在位置, 每一次出栈, 就将front位置的元素取出并删除, 然后front向后+1
  • 每一次入栈, 都根据front和当前元素数量计算出入栈元素应该存入的索引, 然后将元素存入到数组对应索引的位置上

1、接口设计

int size();
boolean isEmpty();
void clear();
void enQueue(E element);
E deQueue();
E fornt();
复制代码

2、代码实现

public class CircleQueue<E> {
    // 记录第0个元素的索引
    private int front;
    // 当前队列存储的元素个数
    private int size;
    // 用来存储元素的数组
    private E[] elements;
    // elements默认容量
    private static final int DEFAULT_CAPACITY = 10;
    // 初始化
    public CircleQueue() {
        elements = (E[]) new Object[DEFAULT_CAPACITY];
    }

    // 当前队列存储的元素数量
    public int size() {
        return size;
    }
    // 当前队列是否为空
    public boolean isEmpty() {
        return size == 0;
    }
    // 入队
    public void enQueue(E element) {
        // 扩容
        ensureCapacity(size + 1);
        // 计算新元素应该添加的位置: (front + size) % elements.length
        elements[(front + size) % elements.length] = element;
        // 数量+1
        size++;
    }
    // 扩充容量
    private void ensureCapacity(int capacity) {
        if (capacity <= elements.length) return;
        capacity = capacity + (capacity >> 1);
        E[] newElements = (E[]) new Object[capacity];

        for (int i = 0; i < size; i++) {
            // 计算元素在旧数组的位置 (i + front) % elements.length
            // 取出元素添加到新数组
            newElements[i] = elements[(i + front) % elements.length];
        }
        elements = newElements;
        front = 0;
    }
    // 出队
    public E deQueue() {
        // 取出元素
        E element = elements[front];
        // 删除元素
        elements[front] = null;
        // front向后移动一位
        front = (front + 1) % elements.length;
        // 数量-1
        size--;
        return element;
    }
    // 查看第0个元素
    public E fornt() {
        // 取出front位置的元素
        return elements[front];
    }
    // 清空队列
    public void clear() {
        for (int i = 0; i < size; i++) {
            elements[i] = null;
        }
        size = 0;
        front = 0;
    }
}
复制代码

相关文章

  • 数据结构与算法 (队列实现篇)

    数据结构与算法 (队列实现篇) 在数据结构与算法中,队列(queue)是一种受限的线性储存结构,特殊之处在于它只允...

  • 排序算法

    什么是算法 书籍推荐 《数据结构与算法分析》 表、栈和队列 树 散列(hash) 优先队列(堆) 排序 定义 问题...

  • 集合相关数据结构与算法

    队列 栈数据结构 比较算法 Collections Collection与Collections的区别?Colle...

  • 数据结构与算法学习开篇

    数据结构与算法知识图谱 20个最常用的、最基础数据结构与算法 10个数据结构:数组、链表、栈、队列、散列表、二叉树...

  • 【数据结构与算法 - Swift实现】10 - 优先队列 (Pr

    在【数据结构与算法 - Swift实现】04 - 队列 (Queue)文章里面,我们已经讲过队列,采用先进先出的规...

  • 数据结构与算法分析:大纲]

    00数据结构与算法分析:大纲01数据结构:数组02数据结构:链表03数据结构:栈03数据结构:队列 本系列课程主要...

  • 数据结构:数组

    00数据结构与算法分析:大纲01数据结构:数组02数据结构:链表03数据结构:栈03数据结构:队列 数组 数组是一...

  • 链式队列的定义,ios基础知识篇!

    数据结构与算法-链式队列 链式队列的定义 链式队列是用链表来实现的队列,不存在队满的情况。链式队列也包里队列的特点...

  • 数据结构与算法之美-09讲队列

    数据结构与算法之美-09讲队列 特别备注 本系列非原创,文章原文摘自极客时间-数据结构算法之美[https://t...

  • 队列

    数据结构与算法 --- 队列 【转载】 原文:https://www.jianshu.com/p/c8f2524e...

网友评论

      本文标题:数据结构与算法(第一季):队列

      本文链接:https://www.haomeiwen.com/subject/iwuqzltx.html