Java 模拟队列(一般队列、双端队列、优先级队列)
队列:
先进先出,处理类似排队的问题,先排的。先处理,后排的等前面的处理完了,再处理
对于插入和移除操作的时间复杂度都为O(1)。从后面插入,从前面移除
双端队列:
即在队列两端都能够insert和remove:insertLeft、insertRight。removeLeft、removeRight
含有栈和队列的功能,如去掉insertLeft、removeLeft,那就跟栈一样了。如去掉insertLeft、removeRight。那就跟队列一样了
一般使用频率较低,时间复杂度 O(1)
优先级队列:
内部维护一个按优先级排序的序列。插入时须要比較查找插入的位置,时间复杂度O(N), 删除O(1)
- /*
- * 队列 先进先出。一个指针指示插入的位置,一个指针指示取出数据项的位置
- */
- public class QueueQ<T> {
- private int max;
- private T[] ary;
- private int front; //队头指针 指示取出数据项的位置
- private int rear; //队尾指针 指示插入的位置
- private int nItems; //实际数据项个数
- public QueueQ(int size) {
- this.max = size;
- ary = (T[]) new Object[max];
- front = 0;
- rear = -1;
- nItems = 0;
- }
- //插入队尾
- public void insert(T t) {
- if (rear == max - 1) {//已到实际队尾,从头開始
- rear = -1;
- }
- ary[++rear] = t;
- nItems++;
- }
- //移除队头
- public T remove() {
- T temp = ary[front++];
- if (front == max) {//列队到尾了,从头開始
- front = 0;
- }
- nItems--;
- return temp;
- }
- //查看队头
- public T peek() {
- return ary[front];
- }
- public boolean isEmpty() {
- return nItems == 0;
- }
- public boolean isFull() {
- return nItems == max;
- }
- public int size() {
- return nItems;
- }
- public static void main(String[] args) {
- QueueQ<Integer> queue = new QueueQ<Integer>(3);
- for (int i = 0; i < 5; i++) {
- queue.insert(i);
- System.out.println("size:" + queue.size());
- }
- for (int i = 0; i < 5; i++) {
- Integer peek = queue.peek();
- System.out.println("peek:" + peek);
- System.out.println("size:" + queue.size());
- }
- for (int i = 0; i < 5; i++) {
- Integer remove = queue.remove();
- System.out.println("remove:" + remove);
- System.out.println("size:" + queue.size());
- }
- System.out.println("----");
- for (int i = 5; i > 0; i--) {
- queue.insert(i);
- System.out.println("size:" + queue.size());
- }
- for (int i = 5; i > 0; i--) {
- Integer peek = queue.peek();
- System.out.println("peek:" + peek);
- System.out.println("size:" + queue.size());
- }
- for (int i = 5; i > 0; i--) {
- Integer remove = queue.remove();
- System.out.println("remove:" + remove);
- System.out.println("size:" + queue.size());
- }
- }
- }
- /*
- * 双端队列<span style="white-space:pre"> </span>两端插入、删除
- */
- public class QueueQT<T> {
- private LinkedList<T> list;
- public QueueQT() {
- list = new LinkedList<T>();
- }
- // 插入队头
- public void insertLeft(T t) {
- list.addFirst(t);
- }
- // 插入队尾
- public void insertRight(T t) {
- list.addLast(t);
- }
- // 移除队头
- public T removeLeft() {
- return list.removeFirst();
- }
- // 移除队尾
- public T removeRight() {
- return list.removeLast();
- }
- // 查看队头
- public T peekLeft() {
- return list.getFirst();
- }
- // 查看队尾
- public T peekRight() {
- return list.getLast();
- }
- public boolean isEmpty() {
- return list.isEmpty();
- }
- public int size() {
- return list.size();
- }
- }
- /*
- * 优先级队列 队列中按优先级排序。是一个有序的队列
- */
- public class QueueQP {
- private int max;
- private int[] ary;
- private int nItems; //实际数据项个数
- public QueueQP(int size) {
- this.max = size;
- ary = new int[max];
- nItems = 0;
- }
- //插入队尾
- public void insert(int t) {
- int j;
- if (nItems == 0) {
- ary[nItems++] = t;
- } else {
- for (j = nItems - 1; j >= 0; j--) {
- if (t > ary[j]) {
- ary[j + 1] = ary[j]; //前一个赋给后一个 小的在后 相当于用了插入排序。给定序列本来就是有序的。所以效率O(N)
- } else {
- break;
- }
- }
- ary[j + 1] = t;
- nItems++;
- }
- System.out.println(Arrays.toString(ary));
- }
- //移除队头
- public int remove() {
- return ary[--nItems]; //移除优先级小的
- }
- //查看队尾 优先级最低的
- public int peekMin() {
- return ary[nItems - 1];
- }
- public boolean isEmpty() {
- return nItems == 0;
- }
- public boolean isFull() {
- return nItems == max;
- }
- public int size() {
- return nItems;
- }
- public static void main(String[] args) {
- QueueQP queue = new QueueQP(3);
- queue.insert(1);
- queue.insert(2);
- queue.insert(3);
- int remove = queue.remove();
- System.out.println("remove:" + remove);
- }
- }
Java 模拟队列(一般队列、双端队列、优先级队列)的更多相关文章
- 自己动手实现java数据结构(四)双端队列
1.双端队列介绍 在介绍双端队列之前,我们需要先介绍队列的概念.和栈相对应,在许多算法设计中,需要一种"先进先出(First Input First Output)"的数据结构,因 ...
- Java数据结构——用双端链表实现队列
//================================================= // File Name : LinkQueue_demo //---------------- ...
- JAVA基础——链表结构之双端链表
双端链表:双端链表与传统链表非常相似.只是新增了一个属性-即对最后一个链结点的引用 如上图所示:由于有着对最后一个链结点的直接引用.所以双端链表比传统链表在某些方面要方便.比如在尾部插入一个链结点.双 ...
- 队列(存储结构双端链表)--Java实现
/*用链表实现的队列--使用的是双端链表 *注意:空指针错误肯定是引用没有指向对象 * */ public class MyLinkedQueue { private MyFirstAndLastLi ...
- [转载]队列queue和双端Dequeue
转载自:http://uule.iteye.com/blog/2095650?utm_source=tuicool 注意:这都只是接口而已 1.Queue API 在java5中新增加了java.ut ...
- 队列Queue、栈LifoQueue、优先级队列PriorityQueue
队列:队列是先进先出. import queue q = queue.Queue() q.put(1) q.put(2) q.put(3) q.put(4) print(q.get()) print( ...
- java数据结构——单链表、双端链表、双向链表(Linked List)
1.继续学习单链表,终于摆脱数组的魔爪了,单链表分为数据域(前突)和引用域(指针域)(后继),还有一个头结点(就好比一辆火车,我们只关心火车头,不关心其它车厢,只需知晓车头顺藤摸瓜即可),头结点没有前 ...
- 并发编程-concurrent指南-阻塞双端队列-链阻塞双端队列LinkedBlockingDeque
LinkedBlockingDeque是双向链表实现的阻塞队列.该阻塞队列同时支持FIFO和FILO两种操作方式,即可以从队列的头和尾同时操作(插入/删除): 在不能够插入元素时,它将阻塞住试图插入元 ...
- Java实现 LeetCode 641 设计循环双端队列(暴力)
641. 设计循环双端队列 设计实现双端队列. 你的实现需要支持以下操作: MyCircularDeque(k):构造函数,双端队列的大小为k. insertFront():将一个元素添加到双端队列头 ...
- Fork/Join框架之双端队列
简介 ForkJoinPool管理着ForkJoinWorkerThread线程,ForkJoinWorkerThread线程内部有一个双端队列,这个双端队列主要由一个数组queue.数组下标queu ...
随机推荐
- linux下编译qt5.6.0静态库——configure配置(超详细,有每一个模块的说明)(乌合之众)
linux下编译qt5.6.0静态库 linux下编译qt5.6.0静态库 configure生成makefile 安装选项 Configure选项 第三方库: 附加选项: QNX/Blackberr ...
- 基于visual Studio2013解决面试题之0807strstr函数
题目
- .Net 4.0特性 Tuple元组
Tuple 字面意思:元组.是.net4.0增加的新特性,是干什么的呢?总结一句,个人觉得这个东西 就是用来在有返回很多种类型的值时可以用到.它提供了8种类型的Tuple,直接看最复杂的那种(其实不是 ...
- 显示出eclipse文件层次
看到图片中右边那个倒三角型符号没, 点一下,弹出个菜单,选package presentation->hierarachial 文件目录结构 flat 是包结构
- UVA 839 (13.08.20)
Not so Mobile Before being an ubiquous communications gadget, a mobile wasjust a structure made of ...
- hadoop深入研究:(五)——Archives
转载请注明来源地址:http://blog.csdn.net/lastsweetop/article/details/9123155 简介 我们在hadoop深入研究:(一)——hdfs介绍里已讲过, ...
- FOJ 1607 Greedy division 数学题
题目地址: http://acm.fzu.edu.cn/problem.php?pid=1607 给定一个n,将n平均分成m份,问有几种方法,每种方法中找出最大的数.思路:就是求n的因子数.先将每个数 ...
- 使用malloc分别分配2KB,6KB的内存空间,打印指针地址
#include<stdio.h> #include<stdlib.h> #include<string.h> #include<malloc.h> i ...
- MFC 单文档中动态添加菜单项和响应菜单事件
新建一个单文档程序 在查看菜单项中增加两个子菜单,分别为隐藏工具栏(ID_HIDE),新建菜单(ID_NEWMENU) 在Resource.h中增加一个ID_NEWMENU宏 #define ID_N ...
- WAS ND集群中的HTTP内存会话复制对Java应用程序序列化编程的要求
应用程序需要遵守的约定 在会话中没有自定义对象时,WAS 集群的 HTTP 会话内存复制特性成功地实现了高可用性,使用户在宕机过程中的会话信息没有丢失,操作没有受到任何影响. 在会话中包含自定义对象时 ...