基础数据结构——队列(链表实现)

队列的性质

  • 先进先出(FIFO - First In First Out):最先加入队列的元素最先被移出
  • 后进后出(后来的元素排在队尾)
  • 只允许在队尾插入元素,在队首删除元素
  • 具有先来先服务的特点

链表实现队列

和之前创建链表相同,我们需要设置一个哨兵头结点 此时它既是head也是tail

后面进行添加操作的之后将每次新加的节点设置为tail,并且指向head

我们接下来实现队列的基本操作

先来写队列类和它内部Node类

java 复制代码
public class LinkedListQueue <E>implements Queue<E>, Iterable<E>{
    Node<E> head=new Node<>(null,null);//头指针一直指向哨兵节点
    Node<E> tail=head;
    int size=0;
    int capacity=Integer.MAX_VALUE;
    {
        tail.next=head;
    }

    private static class Node<E>{
        E value;
        Node<E> next;

      public Node(E value, Node<E> next) {
          this.value = value;
          this.next = next;
    }
}

    public LinkedListQueue(int capacity) {
        this.capacity = capacity;
    }

    public LinkedListQueue() {

}

我们在这个类中将每次构造的队列对象的tail节点都指向head节点

接下来我们实现各个功能操作

代码如下

java 复制代码
public boolean offer(E value) {
        if(isFull()){
            return false;
        }
        Node<E> added=new Node<>(value,head);
        tail.next=added;
        tail=added;
        size++;
        return true;
    }

    @Override
    public E poll() {
        if (isEmpty()){
            return null;
        }
        Node<E> first=head.next;
        head.next=first.next;
        size--;
        return first.value;
    }

    @Override
    public E peek() {
        if(isEmpty()){
            return null;
        }
        return head.next.value;
    }

    @Override
    public boolean isEmpty() {
        return head==tail;
    }

    @Override
    public boolean isFull() {
        return size==capacity;
    }
}
相关推荐
学嵌入式的小杨同学15 小时前
【嵌入式 Linux 实战 1】Ubuntu 环境搭建 + 目录结构详解:嵌入式开发入门第一步
linux·c语言·开发语言·数据结构·vscode·vim·unix
Ada's15 小时前
【计算机基础系列】001:计算机科学与技术
数据结构
梦幻精灵_cq15 小时前
《双征color》诗解——梦幻精灵_cq对终端渲染的数据结构设计模型式拓展
数据结构·python
漫随流水16 小时前
leetcode回溯算法(491.非递减子序列)
数据结构·算法·leetcode·回溯算法
陳103016 小时前
C++:二叉搜索树
开发语言·数据结构·c++
睡一觉就好了。16 小时前
排序--直接排序,希尔排序
数据结构·算法·排序算法
wen__xvn17 小时前
基础算法集训第06天:计数排序
数据结构·算法·leetcode
鱼跃鹰飞17 小时前
LeetCode热题100: 49.字母异位词分组
java·数据结构·算法·leetcode
好奇龙猫18 小时前
【大学院-筆記試験練習:线性代数和数据结构(16)】
数据结构·线性代数·决策树
hope_wisdom18 小时前
C/C++数据结构之用数组实现队列
c语言·数据结构·c++·队列