import java.util.Iterator;

import java.util.NoSuchElementException;

/**
* 使用链表来实现队列
* 1.考虑结点的结构,包括当前结点的元素和模拟的指针指向下一个元素
* 2.结点的结构使用内部类来进行设计
* 3.队列的结构:队列的长度,队列的首节点,队列的尾结点
* 4.考虑队列需要的操作:
* 1.使用构造函数进行初始化
* 2.判断队列是否为空
* 3.返回队列的长度
* 4.向队列尾部中添加元素
* 5.将队列首部元素删除
* 6.格式化输出
* 7.迭代器遍历
* @author WZLOVE
* @create 2018-07-14 18:03
*/
public class LinkedQueue<Item> implements Iterable<Item> { /**
* 定义队列基本元素
*/ /**
* 队列的长度
*/
private int n;
/**
* 队列的首节点
*/
private Node first;
/**
* 队列的尾节点
*/
private Node last; /**
* 定义结点类
*/
private class Node{
private Item item;
private Node next;
} /**
* 使用构造方法初始化队列
* @return
*/
public LinkedQueue() {
this.first = null;
this.last = null;
n = 0;
assert check();
} /**
* 判空
* @return
*/
public boolean isEmpty(){
// 如果对头为null,则表示队列为空
return first == null;
} /**
* 求队列的长度
* @return
*/
public int size(){
return n;
} /**
* 获取对头的元素
* @return
*/
public Item peek(){
if(isEmpty()){
throw new NoSuchElementException("队列为空,没有元素");
}
return first.item;
} /**
* 添加元素
* @return
*/
public void addQueue(Item item){
Node oldNode = last;
last = new Node();
last.item = item;
last.next = null;
if(isEmpty()){
first = last;
} else{
oldNode.next = last;
}
n ++;
assert check();
} /**
* 删除元素
* @return
*/
public Item deQueue(){
if(isEmpty()){
throw new NoSuchElementException("队列为空,不能进行该操作");
}
Item item = first.item;
first = first.next;
n --;
if(isEmpty()){
last = null;
}
assert check();
return item;
} @Override
public String toString() {
StringBuilder sb = new StringBuilder();
for(Item item : this){
sb.append(item + " ");
}
return sb.toString();
} /**
* 返回迭代器
* @return
*/
@Override
public Iterator<Item> iterator() {
return new ListIterator();
} /**
* 实现迭代器接口
*/
private class ListIterator implements Iterator<Item> {
/**
* 队首的元素
*/
private Node current = first; /**
* 判断有无更多元素
* @return
*/
@Override
public boolean hasNext() { return current != null; }
@Override
public void remove() { throw new UnsupportedOperationException(); } /**
* 返回当前元素,移动指针(这样理解就好,实际java中无指针)
* @return
*/
@Override
public Item next() {
if (!hasNext()) throw new NoSuchElementException();
Item item = current.item;
current = current.next;
return item;
}
} /**
*检查队列的结构是否符合要求
* @return
*/
private boolean check() {
if (n < 0) {
return false;
}
else if (n == 0) {
if (first != null) return false;
if (last != null) return false;
}
else if (n == 1) {
if (first == null || last == null) return false;
if (first != last) return false;
if (first.next != null) return false;
}
else {
if (first == null || last == null) return false;
if (first == last) return false;
if (first.next == null) return false;
if (last.next != null) return false; // check internal consistency of instance variable n
int numberOfNodes = 0;
for (Node x = first; x != null && numberOfNodes <= n; x = x.next) {
numberOfNodes++;
}
if (numberOfNodes != n) return false; // check internal consistency of instance variable last
Node lastNode = first;
while (lastNode.next != null) {
lastNode = lastNode.next;
}
if (last != lastNode) return false;
} return true;
} public static void main(String[] args) {
LinkedQueue<String> linkedQueue = new LinkedQueue<>();
linkedQueue.addQueue("迪丽热巴");
linkedQueue.addQueue("杨紫");
linkedQueue.addQueue("李溪芮");
Iterator<String> it = linkedQueue.iterator();
while(it.hasNext()){
System.out.println(it.next());
} System.out.println("============================================================");
System.out.println("队列中有" + linkedQueue.size() + "个元素");
System.out.println("============================================================");
System.out.println(linkedQueue);
}
}

Java之使用链表实现队列的更多相关文章

  1. 教你如何使用Java手写一个基于链表的队列

    在上一篇博客[教你如何使用Java手写一个基于数组的队列]中已经介绍了队列,以及Java语言中对队列的实现,对队列不是很了解的可以我上一篇文章.那么,现在就直接进入主题吧. 这篇博客主要讲解的是如何使 ...

  2. Java数据结构——用双端链表实现队列

    //================================================= // File Name : LinkQueue_demo //---------------- ...

  3. Java并发编程:阻塞队列(转载)

    Java并发编程:阻塞队列 在前面几篇文章中,我们讨论了同步容器(Hashtable.Vector),也讨论了并发容器(ConcurrentHashMap.CopyOnWriteArrayList), ...

  4. 【Java数据结构学习笔记之二】Java数据结构与算法之队列(Queue)实现

      本篇是数据结构与算法的第三篇,本篇我们将来了解一下知识点: 队列的抽象数据类型 顺序队列的设计与实现 链式队列的设计与实现 队列应用的简单举例 优先队列的设置与实现双链表实现 队列的抽象数据类型 ...

  5. 【Java实现】栈和队列就是这么简单

    一.前言 上一篇已经讲过了链表[Java实现单向链表]了,它跟数组都是线性结构的基础,本文主要讲解线性结构的应用:栈和队列 如果写错的地方希望大家能够多多体谅并指正哦,如果有更好的理解的方式也希望能够 ...

  6. java算法01 - 链表

    1.链表 在Java中实现链表,每个节点都有一个值,然后把它链接到下一个节点.下面来看一下节点的实现 class Node<E> { private E e; private Node&l ...

  7. 【转】Java并发编程:阻塞队列

    在前面几篇文章中,我们讨论了同步容器(Hashtable.Vector),也讨论了并发容器(ConcurrentHashMap.CopyOnWriteArrayList),这些工具都为我们编写多线程程 ...

  8. Java并发容器之阻塞队列BlockingQueue

    BlockingQueue提供了线程安全的队列访问方式:当阻塞队列进行插入数据时,如果队列已满,线程将会阻塞等待直到队列非满:从阻塞队列取数据时,如果队列已空,线程将会阻塞等待直到队列非空. Bloc ...

  9. 12、Java并发编程:阻塞队列

    Java并发编程:阻塞队列 在前面几篇文章中,我们讨论了同步容器(Hashtable.Vector),也讨论了并发容器(ConcurrentHashMap.CopyOnWriteArrayList), ...

随机推荐

  1. MyBatis学习(一)————纯jdbc编程

    什么是JDBC  JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java ...

  2. Nginx 配置优化

    一.开启Gzip 1.参数 gzip on;gzip_min_length 1k;gzip_buffers 4 16k;gzip_comp_level 2;gzip_types text/plain ...

  3. 多种方法实现左右固定,中间自适应的CSS布局

    布局是面试中常问的问题,尤其是这类的题目,怎么答才好呢? 大多数人的第一个方法是浮动,没错,浮动.第二个方法呢?你回答定位,没错.第三个方法呢?.... 第四个方法呢?第五个方法呢?.... 其实能想 ...

  4. [buaa-SE-2017]个人作业-Week2

    个人作业-Week2 一.代码复审Checklist 1.概要部分 1.1 代码能符合需求和规格说明么? 本次作业的需求可以分成基本的功能实现和大规模数据下程序的健壮性,以及少量的异常处理能力,也就是 ...

  5. 软工实践-Beta 冲刺 (7/7)

    队名:起床一起肝活队 组长博客:博客链接 作业博客:班级博客本次作业的链接 组员情况 组员1(队长):白晨曦 过去两天完成了哪些任务 描述: 1.界面的修改与完善 展示GitHub当日代码/文档签入记 ...

  6. C++自学及C的补缺

    我这个寒假可以坐在电脑前的时间算是比较少的,因为我放假不久后就去打工了,而打工的时间是很流动的,所以我无法固定时间来学习,因此我只能根据我的打工时间来安排我的学习. 由于我的书是除夕前夕淘宝的,近期是 ...

  7. lintcode-517-丑数

    517-丑数 写一个程序来检测一个整数是不是丑数. 丑数的定义是,只包含质因子 2, 3, 5 的正整数.比如 6, 8 就是丑数,但是 14 不是丑数以为他包含了质因子 7. 注意事项 可以认为 1 ...

  8. AngularJs 学习 (一)

    最近学习了一下关于AngularJs的知识,发现和Vue还是有非常相似的东西.所以对于学过Vue的自己来说,还是比较好理解的 特点:双向数据绑定,单页面应用 控制器: AngularJs控制器可以控制 ...

  9. 014 C语言文法定义与C程序的推导过程

  10. svmtrain和svmpredict简介

    转自:http://blog.sina.com.cn/s/blog_4d7c97a00101bwz1.html 本文主要介绍了SVM工具箱中svmtrain和svmpredict两个主要函数: (1) ...