十一 队列 Queue
队列: 一种先进先出的数据结构 FIFO
数组队列的实现:
队列的实现:
package com.lt.datastructure.Queue;
public class ArrayQueue<E> implements Queue<E> {
private Array1<E> array;
public ArrayQueue(int capacity){
array = new Array1<>(capacity);
}
public ArrayQueue(){
array = new Array1<>();
}
@Override
public int getSize() {
return array.getSize();
}
@Override
public boolean isEmpty() {
return array.isEmpty();
}
@Override
public void enqueue(E e) {
array.addLast(e);
}
@Override
public E dequeue() {
return array.removeFirst();
}
@Override
//查看队首
public E getFront(E e) {
return array.getFirst();
}
@Override
public String toString() {
StringBuilder res = new StringBuilder();
res.append("Queue:");
res.append("front:[");
for(int i=0; i<array.getSize();i++){
res.append(array.get(i));
if(i!=array.getSize()-1){
res.append(",");
}
}
res.append("] tail");
return res.toString();
}
public static void main(String[] args) {
ArrayQueue<Integer> queue = new ArrayQueue<>();
for(int i =0; i<10; i++){
queue.enqueue(i);
System.out.println(queue);
if(i%3==2){
queue.dequeue();
System.out.println(queue);
}
}
}
}
测试:

复杂度;
dequeue:出列操作时,移除队首,其余元素向前移一个位置 O(n)
循环队列:犹如钟表
- front指向队首,tail指向队尾
- 出队时,移动front的指向。
- font==tail时,队列为空
- (tail+1)%Capacity=front,队列满,会有一个元素浪费

循环队列复杂度分析:

循环队列的实现:
package com.lt.datastructure.Queue;
import com.lt.datastructure.Array.Array;
/*
* 循环队列的实现
*/
public class LoopQueue<E> implements Queue<E> {
private int front,tail;
private int size;
E[] data;
public LoopQueue(int capacity){
data = (E[])new Object[capacity+1];
front = 0;
tail = 0;
size = 0;
}
public LoopQueue(){
this(10);
}
//由于空出一个空间,所以容量-1
public int getCapacity() {
return data.length-1;
}
@Override
public boolean isEmpty() {
return front==tail;
}
@Override
public int getSize() {
return size;
}
@Override
public void enqueue(E e) {
//队列满,扩容
if((tail+1) % data.length ==front){
resize(getCapacity()*2);
}
data[tail] = e;
tail = (tail+1)%data.length;
size++;
}
private void resize(int newCapacity) {
E[] newData =(E[])new Object[newCapacity+1];
for(int i=0; i < size; i++){
newData[i] = data[(i+front)%data.length];
}
data = newData;
front = 0;
tail=size;
}
@Override
public E dequeue() {
//查看的队列是否为空
if(isEmpty()){
throw new IllegalAccessError("cannot dequeue from an empty queue.");
}
E ret = data[front];
data[front] = null;
front = (front+1)%data.length;
size--;
if(size==getCapacity()/4 && getCapacity()/2!=0){
resize(getCapacity()/2);
}
return ret;
}
@Override
public E getFront(E e) {
//查看的队列是否为空
if(isEmpty()){
throw new IllegalAccessError("cannot getFront from an empty queue.");
}
return data[front];
}
@Override//覆盖父类方法
public String toString(){
StringBuilder res = new StringBuilder();
res.append(String.format("LoopQueue:size = %d , capacity = %d\n",size,getCapacity()));
res.append("front [");
for(int i = front; i!=tail ; i=(i+1)%data.length){
res.append(data[i]);
if((i+1)%data.length != tail)
res.append(",");
}
res.append("]");
return res.toString();
}
public static void main(String[] args) {
LoopQueue<Integer> queue = new LoopQueue<>();
for(int i =0; i<10; i++){
queue.enqueue(i);
System.out.println(queue);
if(i%3==2){
queue.dequeue();
System.out.println(queue);
}
}
}
}
测试用例:
package com.lt.datastructure.Queue;
import java.util.Random;
public class Main {
/*
* 测试ArrayQueue和LoopQueue
*/
private static double testQueue(Queue<Integer> q , int opCount){
long startTime = System.nanoTime();
//..
Random random = new Random();
for(int i =0; i<opCount;i++){
q.enqueue(random.nextInt(Integer.MAX_VALUE));
}
for(int i=0; i<opCount; i++){
q.dequeue();
}
long endTime = System.nanoTime();
return (endTime-startTime)/1000000000.0;
}
public static void main(String[] args){
int opCount = 100000;
ArrayQueue<Integer> arrayQueue = new ArrayQueue<>();
System.out.println("ArrayQueue:"+testQueue(arrayQueue,opCount));
LoopQueue<Integer> loopQueue = new LoopQueue<>();
System.out.println("LoopQueue:"+testQueue(loopQueue, opCount));
}
}
测试结果:

十一 队列 Queue的更多相关文章
- jQuery 源码分析(十一) 队列模块 Queue详解
队列是常用的数据结构之一,只允许在表的前端(队头)进行删除操作(出队),在表的后端(队尾)进行插入操作(入队).特点是先进先出,最先插入的元素最先被删除. 在jQuery内部,队列模块为动画模块提供基 ...
- Python进阶【第二篇】多线程、消息队列queue
1.Python多线程.多进程 目的提高并发 1.一个应用程序,可以有多进程和多线程 2.默认:单进程,单线程 3.单进程,多线程 IO操作,不占用CPU python的多线程:IO操作,多线程提供并 ...
- Java中的队列Queue,优先级队列PriorityQueue
队列Queue 在java5中新增加了java.util.Queue接口,用以支持队列的常见操作.该接口扩展了java.util.Collection接口. Queue使用时要尽量避免Collecti ...
- jquery 的队列queue
使用示列代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www ...
- Windows Azure Service Bus (2) 队列(Queue)入门
<Windows Azure Platform 系列文章目录> Service Bus 队列(Queue) Service Bus的Queue非常适合分布式应用.当使用Service Bu ...
- Windows Azure Service Bus (3) 队列(Queue) 使用VS2013开发Service Bus Queue
<Windows Azure Platform 系列文章目录> 在之前的Azure Service Bus中,我们已经介绍了Service Bus 队列(Queue)的基本概念. 在本章中 ...
- (C#)使用队列(Queue)解决简单的并发问题
(C#)使用队列(Queue)解决简单的并发问题 2015-07-16 13:04 13265人阅读 评论(8) 收藏 举报 分类: Asp.Net(8) 版权声明:本文为博主原创文章,未经博主允 ...
- STL中的单向队列queue
转载自:http://blog.csdn.net/morewindows/article/details/6950917 stl中的queue指单向队列,使用时,包含头文件<queue>. ...
- java09 队列Queue与Deque
队列Queue与Deque. Enumeration Hashtable与Hashtable子类Properties(资源配置文件) 引用类型(强.软.弱.虚)与WeakHashMap Identit ...
随机推荐
- TakeColor下载及调节鼠标指针不一致的问题
取色器下载链接: 链接:https://pan.baidu.com/s/19TBWZA2ltaLQjzskTipnmg 提取码:2uz3 若出现指针与鼠标不一致: TakeColor v8.0 > ...
- SEO 建站过程复盘
今天在A5看到一篇关于一个牛站的复盘,整个建站过程值得借鉴. https://www.admin5.com/article/20200218/943930.shtml
- 缓存验证Last-Modified和Etag的使用
缓存工作示意图: 在http协议里面,数据的验证方式,主要有两个验证头:Last-Modified 和 Etag. Last-Modified 配合Last-Modified-Since或者If-Un ...
- list的使用-Hdu 1276
士兵队列训练问题 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Su ...
- nfs的原理 安装配置方法 centos6.5
NFS周边 Network File System 作用 像访问本地文件一样去访问NFS服务器上的文件,目录 引用场景: ..1 用户上传的静态文件---图片,视频,用户上传的视频,头像 ..2 中小 ...
- Cosmetic Bottles - Cosmetic Packaging: What Are The Characteristics Of Trends?
There are certain differences in products, of which cosmetics are the most obvious. In addition to t ...
- input输入框type设置为number,maxlength无效
一个小细节,以前很少注意,直到最近做的一个项目,当我把一个输入数字的input框的类型设置为number时,input框还是可以无限输入,设置maxlengh=10就不起作用了.然后我就去百度了一下, ...
- 正则表达式regex回溯分析
正则表达式的回溯 现在我们来正式认识一下回溯.以字符串“abbc”为例,正则表达式为“ab{1,3}c”,再匹配的时候,a.b.b,匹配完成,这时候,正则表达式会继续用c和b进行比较,发现不符合,这时 ...
- mqtt.mini.js 使用
html文件里直接调用 <!DOCTYPE html> <html lang="en"> <head> <meta charset=&qu ...
- 阿里云虚拟主机申请免费SSL证书并成功开通Https访问
参考文档网址 https://baijiahao.baidu.com/s?id=1628343140232374972&wfr=spider&for=pc