一、分析

  队列是一种先进先出的线性表,它只允许在表的一端进行插入,而在另一端删除元素。允许插入的一端称为队尾,允许删除的一端称为队头。

  链队是指采用链式存储结构实现的队列,它的基本操作如下:

    1、初始化链队

    2、销毁链队

    3、清空链队

    4、检测链队是否为空

    5、返回链队的元素个数

    6、返回链队头元素

    7、向队尾插入元素

    8、删除并返回队头元素

    9、遍历链队

  通常链队用单链表来表示,但一个链队还需要两个分别指示队头和队尾的指针才能唯一确定,和单链表一样,为了便于操作,附设一个头结点来指示队头。

  在Java中,我们可以将链队中的结点视作一个类,类中拥有属性data、nextQueue和lastQueue分别表示数据、下一结点和队尾,链队的基本操作即为类的方法,每个结点就是一个对象。这样,初始化链队就是实例化头结点,销毁链队就是将头结点销毁,链队就会因为缺少引用而被销毁。

二、实现

1、定义类属性和构造函数

 class InitQueue{

     private int [] data = new int[1];     //定义成数组是为了可以用null表示空

     private InitQueue nextQueue;

     private InitQueue lastQueue;

     public InitQueue() {             //头结点的初始化
this.data = null;
this.nextQueue = null;
this.lastQueue = this;
} public InitQueue(int data) {       //普通结点的初始化
this.data[0] = data;
this.nextQueue = null;
this.lastQueue = null;
}
}

2、清空链队

 public void clearQueue() {
this.nextQueue = null;     //头节点的下一结点置空
this.lastQueue = this;     //尾指针指向头结点
}

3、检测链队是否为空

 public boolean queueEmpty() {
if(this.nextQueue == null) {
return true;
}
return false;
}

4、返回链队的元素个数

 public int queueLength() {

     InitQueue theQueue = this.nextQueue;      //获取头结点的下一结点地址(链队的第一个结点)
int i = 0; for (i = 0; theQueue != null; i++) {     //循环读取并计数
theQueue = theQueue.nextQueue;
}
return i;
}

5、返回链队头元素

 public int [] getHead() {
if(this.nextQueue == null) {       //如果链队为空,返回空
return null;
}
return this.nextQueue.data;
}

6、向队尾插入元素

 public void enQueue(int input) {
InitQueue initQueue = new InitQueue(input);     //实例化新结点
this.lastQueue.nextQueue = initQueue;         //插入队尾
this.lastQueue = initQueue;              //尾指针指向队尾
}

7、删除并返回队头元素

 public int [] deQueue() {

     if (this.nextQueue == null) {              //如果链队为空,返回null
return null;
} int [] i = this.nextQueue.data;            //获取队头元素数据
this.nextQueue = this.nextQueue.nextQueue;     //头指针向后移动一位 if (this.nextQueue == null) {             //如果链队变空
this.lastQueue = this;              //尾指针重新指向头结点
}
return i;
}

8、遍历链队

 public String queueTraverse() {          //这里用输出元素值表示遍历

     InitQueue theQueue = this.nextQueue;
String s = ""; while(theQueue != null) {          //循环读取
s += theQueue.data[0] + "、";
theQueue = theQueue.nextQueue;
} if(s.length() == 0) {            //如果未读取到元素值,则返回空字符串
return s;
}
return s.substring(0,s.length() - 1);  //除去最后的顿号后返回
}

三、小结

  以上就是链队用Java的实现,由于只定义了整数的数组,因此只能操作整数数据,但链队的基本思想都已实现。

四、纠正

  隔了一段时间又回来看代码,猛地发现这段代码其实还不够完善。(⊙x⊙;)

  将链队的基本操作定义成了InitQueue类的方法,实例化结点时,会使每个结点都拥有这些方法,然而其实只有头结点需要这些方法,其他结点都不需要。

  因此可以将InitQueue类定义成头节点类,而其他节点定义成头节点的内部类,这样,就只有头节点可以操作其他节点。

  由于要修改的地方太多,这里我就不修改了,放在这里提醒自己。(就是因为懒……(><))

Java实现链队的更多相关文章

  1. Java实现链式存储的二叉查找树(递归方法)

    二叉查找树的定义: 二叉查找树或者是一颗空树,或者是一颗具有以下特性的非空二叉树: 1. 若左子树非空,则左子树上所有节点关键字值均小于根节点的关键字: 2. 若右子树非空,则右子树上所有节点关键字值 ...

  2. Java实现链式存储的二叉树

    二叉树的定义: 二叉树(BinaryTree)是n(n≥0)个结点的有限集,它或者是空集(n=0),或者由一个根结点及两棵互不相交的.分别称作这个根的左子树和右子树的二叉树组成. 二叉树的遍历方式主要 ...

  3. java实现链队列

    java实现链队列的类代码: package linkqueue; public class LinkQueue { class Element { Object elem; Element next ...

  4. java实现链式队列

    java实现链式队列...比较简单 package datastruct; public class QueueLink implements Queue { // 定义一个节点内部类 class N ...

  5. JAVA防盗链在报表中的应用实例

    今天我们来聊聊Java防盗链,多说无用,直接上应用案例. 这里所用的工具是报表软件FineReport,搭配有决策系统(一个web前端展示系统,主要用于权限控制),可以采用java防盗链的方式来实现页 ...

  6. java责任链模式及项目实际运用

    1.前言 上次我们认识了java责任链模式的设计,那么接下来将给大家展示责任链模式项目中的实际运用.如何快速搭建责任链模式的项目中运用. 2.简单技术准备 我们要在项目中使用借助这样的几个知识的组合运 ...

  7. java使用链栈实现迷宫求解

    java实现链栈在前面有所介绍:http://www.cnblogs.com/lixiaolun/p/4644141.html java实现链栈的代码: package stackapplicatio ...

  8. java使用链栈实现数制转换

    java实现链栈在前面有所介绍:http://www.cnblogs.com/lixiaolun/p/4644141.html 将前面java实现链栈的代码稍作修改: package linkedst ...

  9. C++实现链队类——合肥工业大学数据结构实验5:链式队列

    实验5 5.1 实验目的 熟练掌握队列的顺序链式存储结构. 熟练掌握队列的有关算法设计,并在链队列上实现. 根据具体给定的需求,合理设计并实现相关结构和算法. 5.2 实验要求 5.2.1链队列实验要 ...

随机推荐

  1. nuxt使用教程

    1 引言 Nuxt 是基于 Vue 的前端开发框架,这次我们通过 Introduction toNuxtJS 视频了解框架特色以及前端开发框架的基本要素. nuxt 与 next 结构很像,可以结合在 ...

  2. 论一种基于JS技术的WEB前端动态生成框图的方法

    前言 HTML是一种标记语言,由HTML的标签元素和文本编写的文档可被浏览器描述为一幅网页.通常情况下网页的实现是由HTML.CSS和Javascript三者结合完成的,HTML负责网页的结构,CSS ...

  3. 使用<bind>元素创建变量

    在使用模糊查询sql时,如果使用${}进行字符拼接,无法防止sql诸如问题,如果使用concat函数则只对mysql有效果,用Oracle则需要用连接符||,这样在数据库变的时候需要修改,不利于移植. ...

  4. apidoc 接口文档系统

    代码未动,文档先行.apidoc可以方便地维护接口文档.模拟响应数据.前后端分离.导出PDF文档. 特性说明 可视化编辑:支持表单界面编辑接口,不必手动编辑swagger.json 接口模拟响应:支持 ...

  5. MongDB的DateZone

    先理解:Date本身是没有格式的,只是一个毫秒数,要显示成某种格式就一定是字符串 https://github.com/ewcmsfree/ewcms/wiki/Help-mongo-java-dri ...

  6. 1.springboot启动流程

    SpringBoot版本:2.1.2.RELEASE 1.maven <parent> <groupId>org.springframework.boot</groupI ...

  7. mha之vip漂移 配置binlog-server备份服务器 Atlas

    MHAvip漂移 配置 通过MHA自带脚本方式,管理虚拟IP的漂移 获取管理脚本master_ip_failover cp master_ip_failover /usr/local/bin/ #脚本 ...

  8. ctf密码学------密文解码python脚本(凯撒解密)

    题目来源实验吧 分析题意,说是困在栅栏中,所以将字符栅栏解密看看有什么,利用工具CTFcraktools 得到三条密文 然后说是密码是凯撒,在将四栏依次凯撒解码,寻找可能的key,这里很显然,在尝试第 ...

  9. 关闭tslint

    只需要在tslint.config里配置一行 "defaultSeverity": "none",

  10. PCD(点云数据)文件格式

    博客转载自:http://www.pclcn.org/study/shownews.php?lang=cn&id=54 为什么用一种新的文件格式? PCD文件格式并非白费力气地做重复工作,现有 ...