队列——Java实现
1 package struct;
2
3 interface IQueue{
4 //入队列
5 void add(Object obj);
6 //出队列
7 Object remove();
8 //队列中元素个数(栈大小)
9 int size();
10 //判断队列是否为空
11 boolean isEmpty();
12 //取队头元素
13 Object getQueueHead();
14 //取队尾元素
15 Object getQueueTail();
16 //清空队列
17 void clear();
18 }
19 class Factory3{
20 private Factory3(){}
21 public static IQueue getIQueueInstance(){
22 return new LinkQueueImpl();
23 }
24 }
25 class LinkQueueImpl implements IQueue{
26 Node head;//队列的头
27 Node tail;//队列的尾
28 int size;
29 class Node{
30 Node prev;
31 Node next;
32 Object data;
33 public Node(Object data) {
34 super();
35 this.data = data;
36 }
37 }
38 //入队列(头插)
39 public void add(Object obj) {
40 Node newNode = new Node(obj);
41 //空队列
42 if(head == null){
43 head = newNode;
44 tail = newNode;
45 size++;
46 }else{
47 Node node = tail;
48 newNode.next = node;
49 node.prev = newNode;
50 tail = newNode;
51 size++;
52 }
53 }
54 //出队列(尾删)
55 public Object remove() {
56 if(isEmpty()){
57 return "无要删除元素";
58 }else if(head == tail){
59 //只有一个元素的队列
60 size--;
61 return head.data;
62 }else{
63 Node node = head;
64 head = node.prev;
65 node.prev = null;
66 size--;
67 return head.data;
68 }
69 }
70 //求队列长度
71 public int size() {
72 return size;
73 }
74 //求队列是否为空
75 public boolean isEmpty() {
76 return (size()==0);
77 }
78 //取队首元素
79 public Object getQueueHead() {
80 return head.data;
81 }
82 //取对尾元素
83 public Object getQueueTail() {
84 return tail.data;
85 }
86 //打印队列
87 public void print(){
88 myPrint(head);
89 }
90 //队首到对尾打印元素
91 private void myPrint(Node head){
92 for(Node node = head;node!=null;node = node.prev){
93 System.out.print(node.data+" ");
94 }
95 }
96 //置空队列
97 public void clear() {
98 if(head == null){
99 System.out.println("空队列");
100 }else{
101 //非空队列
102 Node node1 = tail;
103 Node node = head;
104 for(node = head;head!=tail;){
105 head = head.prev;
106 node.prev = null;
107 node.data = null;
108 size--;
109 }
110 node1.next = null;
111 node1.data = null;
112 size--;
113 }
114 }
115 }
116 public class LinkQueue {
117 public static void main(String[] args) {
118 IQueue queue = Factory3.getIQueueInstance();
119 //向下转型
120 LinkQueueImpl queue1 = (LinkQueueImpl)queue;
121 System.out.println("以下为空队列测试情况");
122 System.out.println("================remove测试函数==================");
123 System.out.println(queue.remove());
124 System.out.println("================size测试函数==================");
125 System.out.println(queue.size());
126 System.out.println("================isEmpty测试函数==================");
127 System.out.println(queue.isEmpty());
128 System.out.println("以下为非空队列测试情况");
129 System.out.println("================add和print测试函数==================");
130 queue.add("hello");
131 queue.add("world!");
132 queue.add("hi");
133 queue.add("陕科大!");
134 queue.add("today");
135 queue.add("is");
136 queue.add("4月18号!");
137 queue1.print();
138 System.out.println();
139 System.out.println("================getQueueHead测试函数==================");
140 System.out.println(queue.getQueueHead());
141 System.out.println("================getQueueTail测试函数==================");
142 System.out.println(queue.getQueueTail());
143 System.out.println("================remove测试函数==================");
144 System.out.println(queue.remove());
145 System.out.println(queue.remove());
146 System.out.println("================remove后print测试函数==================");
147 queue1.print();
148 System.out.println();
149 System.out.println("================size测试函数==================");
150 System.out.println(queue.size());
151 System.out.println("================isEmpty测试函数==================");
152 System.out.println(queue.isEmpty());
153 System.out.println("================clear测试函数==================");
154 queue.clear();
155 System.out.println(queue.size());
156 }
157 }

队列——Java实现的更多相关文章
- java中使用队列:java.util.Queue (转)
Queue接口与List.Set同一级别,都是继承了Collection接口.LinkedList实现了Queue接 口.Queue接口窄化了对LinkedList的方法的访问权限(即在方法中的参数类 ...
- 队列-java代码
public class QueueDemo { private int maxSize; private long[] queueArray; // 队列的头,实际是数组的尾 private int ...
- java中使用队列:java.util.Queue
在java5中新添加了java.util.Queue接口,用以支持队列的常见操作.该接口扩展了java.util.Collection接口.Queue使用时要尽量避免Collection的add()和 ...
- 阻塞队列 - java基于链表的简单实现
1.阻塞队列的原理 阻塞队列与普通队列的区别在于:阻塞队列为空时,从队列中获取元素的操作将会被阻塞,当队列为满时,往队列里添加元素的操作会被阻塞. 试图从空的阻塞队列中获取元素的线程将会被阻塞,直到其 ...
- 剑指offer【05】- 用两个栈实现队列(java)
题目:用两个栈实现队列 考点:栈和队列 题目描述:用两个栈来实现一个队列,完成队列的Push和Pop操作. 队列中的元素为int类型. 解题思路:每次psuh是时先将stack2清空放入stck1(保 ...
- java中使用队列:java.util.Queue(转)
队列是一种特殊的线性表,是运算受到限制的一种线性表,只允许在表的一端进行插入,而在另一端进行删除元素的线性表.队尾(rear)是允许插入的一端.队头(front)是允许删除的一端.空队列是不含元素的空 ...
- 网站架构:消息队列 Java后端架构
2017-01-13 一.消息队列概述 消息队列中间件是分布式系统中重要的组件,主要解决应用耦合,异步消息,流量削锋等问题.实现高性能,高可用,可伸缩和最终一致性架构.是大型分布式系统不可缺少的中间 ...
- redis实现消息队列-java代码实现
转:https://blog.csdn.net/qq_42175986/article/details/88576849 pom.xml <!-- redis依赖 --> <depe ...
- 05.用两个栈实现队列 Java
题目描述 用两个栈来实现一个队列,完成队列的Push和Pop操作. 队列中的元素为int类型. 思路 进栈: 直接进stack1 出栈: 若stack2不为空,则出栈. 否则,当stack1不为空时, ...
- (超详细)动手编写 — 栈、队列 ( Java实现 )
目录 前言 栈 概念 栈的设计 编码实现 小结 队列 概念 队列的设计 编码实现 双端队列 概念 设计 编码 循环队列 循环队列 循环双端队列 声明 前言 栈 概念 什么是栈? **栈 **:是一种特 ...
随机推荐
- 设计模式学习-使用go实现单例模式
单例模式 定义 优点 缺点 适用范围 代码实现 懒汉模式 饿汉模式 双重检测 sync.Once 参考 单例模式 定义 什么是单例模式:保证一个类仅有一个实例,并提供一个全局访问它的全局访问点. 例如 ...
- ES6基础知识(Promise 对象)
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 大爽Python入门教程 2-3 字符串,列表,字典
大爽Python入门公开课教案 点击查看教程总目录 除了通用的序列方法, 列表和字符串还有些自己的专属方法. 后面介绍有些是英中文对照介绍(英文来自官方文档), 便于大家更深入的去理解其意思. 灵活的 ...
- 菜鸡的Java笔记 - java 线程的同步与死锁 (同步 synchronization,死锁 deadlock)
线程的同步与死锁 (同步 synchronization,死锁 deadlock) 多线程的操作方法 1.线程同步的产生与解决 2.死锁的问题 ...
- CTF入门学习3->Web通信基础
Web安全基础 01 Web通信 这个部分重点介绍浏览器与Web服务器的详细通信过程. 01-00 URL协议 只要上网访问服务器,就离不开URL. URL是什么? URL就是我们在浏览器里输入的站点 ...
- 从一个小Bug,到Azure DevOps
1. 一个小Bug 最近和同事提起一个几年前的 Bug,那是一个很小很小的 Bug,没什么技术含量.那时候我刚入职,正好公司卖了一款仪器到某个国家,但是那边说配套的软件运行不起来,一打开就报错.经过排 ...
- 【原】MDC日志链路设计
背景 我们项目中现有日志系统,采用的是slf4j+logback这套日志组件,也是Java生态里面比较常用的一个日志组件,但是随着分布式的演进,这套组件明显存在以下几个问题: 1.各种无关日志穿行其中 ...
- vue项目中使用canvas
canvas API 文档:https://www.canvasapi.cn/ 一.在html中使用canvas canvas 元素用于在网页上绘制图形. 在html中,使用 document.ge ...
- [CSP-S2019] 树的重心
也是一个很不错的题目. 考虑我们钦定重心为根. 那么就有这样一个性质: 如果我们断的边在一个点的子树里,则这个点不会成为断边后的分裂树的根. 所以我们就只要考虑断边在子树外即可. 那么我们设\(x\) ...
- 【POJ2018】【实数域上的二分】【dp】
传送门:http://poj.org/problem?id=2018: 大概题意是求一个正整数数列 A 的平均数最大 长度不小于 L 的子段 我们可以二分答案 判定是否有一个长度不小于L的子段 平均数 ...