队列的实现(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;
    }
相关推荐
亦暖筑序1 小时前
Java 8老系统AI Workflow实战:把一次性AI对话升级成可恢复工作流
java·后端
敲代码的彭于晏2 小时前
Bean 生命周期完全图解:前端同学也能看懂的 Spring 核心机制
java·前端·后端
plainGeekDev3 小时前
ButterKnife → ViewBinding
android·java·kotlin
像我这样帅的人丶你还19 小时前
Java 后端详解(四):分页与搜索
java·javascript·后端
她的男孩19 小时前
数据权限为什么不能只靠注解?Forge 的 Mapper 层 SQL 改写源码拆解
java·后端·架构
tntxia20 小时前
Mybatis的日志输入
java
亦暖筑序21 小时前
Java 8老系统Browser Agent实战:三层拦截把AI操作后台变成可审计流程
java·后端·设计模式
用户298698530141 天前
Java 实现 Word 文档加密与权限解除
java·后端
Yeats_Liao1 天前
14:Servlet中的页面跳转-Java Web
java·后端·架构
未秃头的程序猿1 天前
告别"if-else地狱"!Java 21模式匹配,代码优雅了10倍
java·后端·面试