文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Java自定义实现链队列详解

2023-05-30 19:04

关注

一、写在前面

        数据结构中的队列应该是比较熟悉的了,就是先进先出,因为有序故得名队列,就如同排队嘛,在对尾插入新的节点,在对首删除节点.jdk集合框架也是提供也一个Queue的接口.这个接口代表一个队列.顺序队列:ArrayBlockingQueue,LinkedBlockingQueue.(上面两种是足色队列)还有一种是ConcurentLinkedQueue。
底层的实现由数组合链表两种的,数组的实现会有个弊端的,会造成假满的现象,开始的时候,队列为空的时候,对首引用变量个对尾的引用变量都为null,随着删除队列的元素,就会发生front+1,rear等于底层数组的容量了.在顺序的存储结构中,front总是保存这着队列中即将出队列的元素的索引,rear总是保存着即将进入队列的元素的索引.队列中的元素的个数就是rear-front的.在顺序的队列中,底层是数组,所以保存 的数据元素是不会改变的,改变的只有rear和front这两个引用变量.
        这里采用链式存储可以有效的利用空间的,就是引用变量要占用额外的空间的.

队列的常用的操作:

             1:初始化
             2:返回队列的长度
             3:添加元素
             4:删除元素
             5:访问对首的元素
             6:访问队列的对尾的元素
             7:判断队列是否为空
             8:清空队列

二、自定义的实现

源码展示的比较清楚,就不用再多做介绍

public class LinkedQueue<T>{//自定义链队列--采用非静态内部类来表示链队列的数据节点private class Node{//表示链队列的数据节点 private T data;//指向下一个节点的引用private Node next; @SuppressWarnings("unused") public Node(){ }public Node(T data,Node next){ this.data=data; this.next=next; }}//定义链队列的对首和对尾的引用 private Node front; private Node rear; //定义链栈的大小private int size; //创建一个空的链对列public LinkedQueue(){ front=null; rear=null;}//以确定的元素来创建一个链对列,只有一个节点的public LinkedQueue(T element){front=new Node(element,null);//指向同一个元素rear=front;size++;}//返回链队列的大小public int length(){return size;}//返回链队列得对首的元素,不删除对首的元素public T elementFront(){if(!empty()){ return front.data;}else{ return null;  }}//访问队列的最后一个元素public T elementRear(){if(!empty()){ return rear.data; }else{ return null; } }//返回当前的链对队列是否为空public boolean empty(){ return size==0; }//清空一个链队列public void clear(){ front=null; rear=null; size=0;}//插入链队列一个节点--对尾public void add(T element){ //如果链对列为空,就新建一个节点 if(front==null){ rear=new Node(element,null); front=rear; }else{ //动态创建新节点 Node newRear=new Node(element,null); rear.next=newRear; rear=newRear; }size++;}//删除链队列一个节点,返回删除后的节点public T remove(){   Node oldFront=front;   front=front.next;   oldFront.next=null;   size--;   return oldFront.data;}//返回队列public String toString(){ //如果链队列为空链队列是 if(empty()){ return "[]"; }else{ StringBuilder sBuilder=new StringBuilder("["); for(Node current=front;current!=null;current=current.next){ sBuilder.append(current.data.toString()+",");} int len=sBuilder.length();return sBuilder.delete(len-1, len).append("]").toString();}}public static void main(String[] args) { LinkedQueue<String> lQueue=new LinkedQueue<String>(); lQueue.add("aaa"); lQueue.add("bbb"); lQueue.add("ccc"); lQueue.add("ddd");System.out.println("返回队列的头结点的数值:"+lQueue.elementFront());System.out.println("返回队列的尾节点的数值:"+lQueue.elementRear());System.out.println(lQueue.length());System.out.println(lQueue);}}  

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 资料下载
  • 历年真题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯