Java双向链表实现队列
将双向链表做简单的改造,即可实现一个FIFO(First Input First Out)队列,
该队列只在头节点出队,尾节点入队。
一般来说定义节点类只需一个后驱节点next即可。
这里保留pre节点,模拟一个已经入队的节点,如果需要取消,这样pre节点就是一个优势。
定义节点类:
/**
* 队列元素
*/
public class Node
{
private int data;//数据域
private Node pre;//指向上一个节点
private Node next;//指向下一个节点 public int getData() {
return data;
}
public void setData(int data) {
this.data = data;
}
public Node getPre() {
return pre;
}
public void setPre(Node pre) {
this.pre = pre;
}
public Node getNext() {
return next;
}
public void setNext(Node next) {
this.next = next;
} //构造函数
public Node(int data, Node pre, Node next){
this.data = data;
this.pre = pre;
this.next = next;
}
public Node(int data){
this(data,null,null);
}
public Node(){
this(0,null,null);
} }
队列实现:

1 /**
2 * Java双向链表实现队列(FIFO)
3 * Author:hangwei
4 * 2022/11
5 */
6 public class DQueue {
7 private Node head;
8 private Node tail;
9 private int size;
10 public Node getHead() {
11 return head;
12 }
13 public Node getTail() {
14 return tail;
15 }
16 public DQueue(){
17 tail = head = null;
18 size = 0;
19 }
20
21 //尾部入队
22 public void add(Node target){
23 if(target == null)
24 return;
25 if (size == 0) {
26 target.setPre(target);
27 target.setNext(target);
28 tail = head = target;
29 } else{
30 tail.setNext(target);//尾节点的下一个节点是新节点
31 target.setPre(tail);//新节点的上一个节点是尾节点
32 //标记新的尾节点
33 tail = target;
34 }
35 size++;
36 }
37
38 //头节点出队or取消某个已入队节点
39 public void romove(Node target){
40 if(size == 0){
41 System.out.println("null linked list ,can not delete.");
42 return;
43 }
44 else if(size == 1){
45 head = tail = null;
46 }
47 else if(target == null || target.equals(head)) {//target为空或头节点,则头出队
48 head = head.getNext();
49 head.setPre(null);
50 }
51 else {//移除队列中指定的元素
52 target.getPre().setNext(target.getNext());
53 target.getNext().setPre(target.getPre());
54 if(target.equals(tail))//如果出队是尾节点
55 tail=target.getPre();//标记新的尾节点
56 }
57 size--;
58 }
59
60 //打印队列
61 public void print(){
62 Node node = new Node();
63 node = head;
64 while (node.getNext() != head && node.getNext() != null){//遍历
65 System.out.print(node.getData());
66 System.out.print("<->");
67 node = node.getNext();
68 }
69 System.out.print(node.getData());//补充打印循环体的最后一个节点
70 System.out.println();
71 }
72 }
测试:
public class Main {
public static void main(String[] args) {
DQueue dq = new DQueue();
dq.add(new Node(111));
dq.add(new Node(222));
dq.add(new Node(333));
dq.add(new Node(444));
dq.add(new Node(555));
dq.print();
dq.romove(null);
dq.print();
dq.romove(dq.getHead().getNext());
dq.print();
}
}
执行结果:

*重点:使用双指针链表实现队列,可以很方便的移除队列中某个不需要的元素。
Java双向链表实现队列的更多相关文章
- Java多线程 阻塞队列和并发集合
转载:大关的博客 Java多线程 阻塞队列和并发集合 本章主要探讨在多线程程序中与集合相关的内容.在多线程程序中,如果使用普通集合往往会造成数据错误,甚至造成程序崩溃.Java为多线程专门提供了特有的 ...
- Java 中的队列 Queue
一.队列的定义 我们都知道队列(Queue)是一种先进先出(FIFO)的数据结构,Java中定义了java.util.Queue接口用来表示队列.Java中的Queue与List.Set属于同一个级别 ...
- java实现链队列
java实现链队列的类代码: package linkqueue; public class LinkQueue { class Element { Object elem; Element next ...
- Java服务器端消息队列实战
服务端口监听--报文接收--报文解码--业务处理--报文编码--写回客户端 从服务端与客户端成功握手并产生一个socket后,为了提高吞吐能力,接下来的事情就可以交给多线程去处理. 为了对接入的请求做 ...
- 使用goroutine+channel和java多线程+queue队列的方式开发各有什么优缺点?
我感觉很多项目使用java或者c的多线程库+线程安全的queue数据结构基本上可以实现goroutine+channel开发能达到的需求,所以请问一下为什么说golang更适合并发服务端的开发呢?使用 ...
- java中有界队列的饱和策略(reject policy)
文章目录 AbortPolicy DiscardPolicy DiscardOldestPolicy CallerRunsPolicy 使用Semaphore java中有界队列的饱和策略(rejec ...
- Java集合--阻塞队列及各种实现的解析
阻塞队列(Blocking Queue) 一.队列的定义 说的阻塞队列,就先了解下什么是队列,队列也是一种特殊的线性表结构,在线性表的基础上加了一条限制:那就是一端入队列,一端出队列,且需要遵循FIF ...
- Java:阻塞队列
Java:阻塞队列 本笔记是根据bilibili上 尚硅谷 的课程 Java大厂面试题第二季 而做的笔记 1. 概述 概念 队列 队列就可以想成是一个数组,从一头进入,一头出去,排队买饭 阻塞队列 B ...
- Java并发--阻塞队列
在前面几篇文章中,我们讨论了同步容器(Hashtable.Vector),也讨论了并发容器(ConcurrentHashMap.CopyOnWriteArrayList),这些工具都为我们编写多线程程 ...
- java代码实现队列的优化
package com.voole.queun; /** * @Decription 队列 * @author TMAC-J * */ public class Queun { /** * 初始化队列 ...
随机推荐
- sql server 自动核算
USE tempdb; CREATE TABLE #temptable ( [姓名] NVARCHAR(255), [加班日期] DATE, [加班时长] DECIMAL(8, 2) ); INSER ...
- 解决git仓库项目 添加到github非空仓库冲突问题 error: failed to push some refs to 'https://github.com/Qtoken/......'
error: failed to push some refs to 'https://github.com/Qtoken/......' 1. 问题描述:执行命令:git push origin m ...
- Delphi注解(不是注释)
开发环境Delphi XE10 1 unit Unit1; 2 3 interface 4 5 uses 6 Winapi.Windows, Winapi.Messages, System.SysUt ...
- 10.7 2020 实验 5:OpenFlow 协议分析和 OpenDaylight 安装
一.实验目的 回顾 JDK 安装配置,了解 OpenDaylight 控制的安装,以及 Mininet 如何连接:通过抓包获取 OpenFlow 协议,验证 OpenFlow 协议和版本,了解协议内容 ...
- 关于Centos7Th 初始化的一些概述
- 概述 Q:为什么要初始化,什么是初始化? A:一般初始化是根据的后期要部署的业务环境来定制的,新装的系统其自带的软件不够支撑各种开发环境或者运维工作:需要部署和设置对应的安全环境.开发/运维软件. ...
- 持续集成环境(4)-Jenkins凭证管理
凭据可以用来存储需要密文保护的数据库密码.Gitlab密码信息.Docker私有仓库密码等,以便 Jenkins可以和这些第三方的应用进行交互. 安装Credentials Binding插件 要在J ...
- selenium--- 数据驱动测试 ddt
通过使用数据驱动测试的方法,可以在需要验证多组数据的测试场景中,使用外部数据源实现对输入值和期望值的参数化,从而避免在测试中仅使用硬编码的数据.将测试数据和测试脚本分离开,使得测试脚本在不同数据集合下 ...
- word多级标题自动编号设置
1.选择段落 ->多级列表 ->定义新的多级列表 2.级别设置 ,这里操作比较繁琐,要多注意[输入编号的格式]要通过[包含的级别编号来自]这一项目来设定 标题1: 标题2 标题3: 标题4 ...
- 关于如何编写好金融科技客户端SDK的思考
引言 回想起来,我在目前的团队(金融科技领域)待了有很长一段时间了,一直在做SDK研发,平时工作中经历过大刀阔斧一蹴而就的喜悦,也经历过被一个问题按在地上摩擦,无奈"废寝忘食"的不 ...
- RTC 科普视频丨聊聊空间音频的原理与其背后的声学原理
在现在很多的线上实时互动场景中,我们重视的不仅仅是互动体验,还要提升沉浸感.而在很多场景中,仅凭空间音频技术,就可以带来如临其境的体验.空间音频技术的原理是怎样的呢? 看过我们新一期的 RTC 科普视 ...