队列的实现(Java)

一、初始化

java 复制代码
public class MyQueue {
    public static class ListNode{
        ListNode next;
        ListNode prev;
        int val;
        public ListNode(int val) {
            this.val = val;
        }
    }
    private ListNode first;
    private ListNode last;
    private int size;
}

使用first和last方便后续内容实现

二、判空

java 复制代码
    public boolean isEmpty() {
        return first == null;
    }

只需要判断首个节点是否为空

三、入队列

java 复制代码
    public void offer(int val) {
        ListNode newNode = new ListNode(val);
        if (first == null) {
            first = newNode;
            last = newNode;
        }else{
            last.next = newNode;
            newNode.prev = last;
        }
        last = newNode;
        size++;
    }

first不动,移动last即可,除非只有一个节点,否则first永远为队头,last永远为队尾

四、peek

java 复制代码
    public int peek() {
        if (isEmpty()) {
            return -1;
        }
        return first.val;
    }

五、出队列

java 复制代码
    public int pop() {
        if (isEmpty()) {
            return -1;
        }
        int x = first.val;
        if(first.next == null){
            first = null;
            last = null;
        }else{
            first = first.next;
            first.prev.next = null;
            first.prev = null;
        }
        size--;
        return x;
    }

实际上first.prev.next = null 可以去掉因为first已经位于下一个节点,只需保证first.prev=null即可

六、size

java 复制代码
    public int size() {
        return size;
    }
相关推荐
Highcharts.js3 小时前
倒置百分比堆叠面积图表示列详解|Highcharts大气成分图表代码
开发语言·信息可视化·highcharts·图表开发·面积图·图表示例·推叠图
csdn_aspnet3 小时前
C语言 Lomuto分区算法(Lomuto Partition Algorithm)
c语言·开发语言·算法
Dicky-_-zhang3 小时前
消息队列Kafka/RocketMQ选型与高可用架构:从单体到100万TPS的演进
java·jvm
晨曦中的暮雨3 小时前
4.15腾讯 CSIG云服务产线 一面
java·开发语言
存在morning3 小时前
【GO语言开发实践】二 GO 并发快速上手
大数据·开发语言·golang
fake_ss1983 小时前
AI时代学习全栈项目开发的新范式
java·人工智能·学习·架构·个人开发·学习方法
茉莉玫瑰花茶3 小时前
工作流的常见模式 [ 1 ]
java·服务器·前端
未若君雅裁4 小时前
Spring AOP、日志切面与声明式事务原理
java·后端·spring
No8g攻城狮4 小时前
【人大金仓】wsl2+ubuntu22.04安装人大金仓数据库V9
java·数据库·spring boot·非关系型数据库
xiaoerbuyu12335 小时前
开源Java 邮箱 基于SpringBoot+Vue前后端分离的电子邮件
java·开发语言