iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Java自定义实现链队列详解
  • 237
分享到

Java自定义实现链队列详解

java链队列ava 2023-05-30 19:05:01 237人浏览 泡泡鱼
摘要

一、写在前面        数据结构中的队列应该是比较熟悉的了,就是先进先出,因为有序故得名队列,就如同排队嘛,在对尾插入新的节点,在对首删除节点.jdk集合框

一、写在前面

        数据结构中的队列应该是比较熟悉的了,就是先进先出,因为有序故得名队列,就如同排队嘛,在对尾插入新的节点,在对首删除节点.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);}}  

--结束END--

本文标题: Java自定义实现链队列详解

本文链接: https://www.lsjlt.com/news/220534.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Java自定义实现链队列详解
    一、写在前面        数据结构中的队列应该是比较熟悉的了,就是先进先出,因为有序故得名队列,就如同排队嘛,在对尾插入新的节点,在对首删除节点.jdk集合框...
    99+
    2023-05-30
    java 链队列 ava
  • C++代码实现链队列详解
    目录主要功能:完整代码展示:总结主要功能: 初始化、入队、出队、取队头元素、销毁队列、输出队列 完整代码展示: #include <iostream> using n...
    99+
    2024-04-02
  • java队列实现方法(顺序队列,链式队列,循环队列)
    双向顺序队列ArrayDeque和双向链式队列LinkedList,JDK已经包含,在此略。ArrayDeque包括顺序栈和顺序队列,LinkedList包含链式栈和链式队列。ArrayDeque和LinkedList都是线程不安全的。Pr...
    99+
    2023-05-30
    java 队列 顺序
  • 数组实现Java 自定义Queue队列及应用操作
    数组实现Java 自定义Queue队列及应用 Java 自定义队列Queue: 队列的抽象数据类型就是一个容器,其中的对象排成一个序列,我们只能访问和取出排在最前端( Front)的...
    99+
    2024-04-02
  • C语言详解链式队列与循环队列的实现
    目录队列的实现链式队列链式队列的定义链式队列的实现循环队列循环队列的定义循环队列的实现队列的实现 队列是一种先进先出(First in First Out)的线性表,简称FIFO。与...
    99+
    2024-04-02
  • Java如何自定义线程池中队列
    目录背景问题分析问题解决总结两个队列的UML关系图SynchronousQueue的定义ArrayBlockingQueue的定义分析jdk源码中关于线程池队列的说明背景 业务交互的...
    99+
    2024-04-02
  • Java怎么自定义线程池中队列
    本篇内容介绍了“Java怎么自定义线程池中队列”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!背景业务交互的过程中涉及到了很多关于SFTP下载...
    99+
    2023-07-02
  • 详解Java如何实现自定义注解
    目录概念作用JDK中预定义的一些注解注解生成文档案例自定义注解格式本质属性:接口中的抽象方法元注解:用于描述注解的注解在程序使用(解析)注解:获取注解中定义的属性值案例:通过自定义注...
    99+
    2024-04-02
  • django+celery+RabbitMQ自定义多个消息队列的实现
    关于django celery的使用网上有很多文章,本文就不多做更多的说明。 本文使用版本 python==3.8.15Django==3.2.4celery==5.2.7 cele...
    99+
    2023-02-22
    django celery RabbitMQ消息队列 django celery 消息队列
  • Java中线程池自定义实现详解
    目录前言线程为什么不能多次调用start方法线程池到底是如何复用的前言 最初使用线程池的时候,网上的文章告诉我说线程池可以线程复用,提高线程的创建效率。从此我的脑海中便为线程池打上了...
    99+
    2023-03-01
    Java线程池自定义 Java线程池
  • SpringBoot自定义Redis实现缓存序列化详解
    目录1、自定义RedisTemplate1.1、Redis API默认序列化机制1.2、自定义RedisTemplate序列化机制1.3、效果测试2、自定义RedisCacheMan...
    99+
    2024-04-02
  • java固定大小队列的几种实现方式详解
    目录前言基于Hutool中的FixedLinkedHashMap基于Guava的EvictingQueue基于Redis的list操作总结前言 最近团队有同学在开发中,遇到一个需求,...
    99+
    2024-04-02
  • JAVA队列( Queue ) 详解
    队列(Queue)是一种常见的数据结构,它遵循先进先出(First-In-First-Out,FIFO)的原则。在队列中,新元素插入...
    99+
    2023-09-15
    Java
  • Java栈和基础队列的实现详解
    目录栈(stack)栈支持的三个核心操作:栈的常见实际应用:栈的实现队列无论是哪种队列,都必须支持三个核心操作:基础队列的实现 栈和队列:都是线性表,都是基于List基础上...
    99+
    2024-04-02
  • java实现队列queue数据结构详解
    目录概念队列中两个主要操作队列遵循以下条件:队列的数组实现总结概念 队列是一种非原始(特殊)的线性表,是一种先进先出(FIFO)的数据结构。它只允许在表的前端(front)进行删除操...
    99+
    2024-04-02
  • Java队列篇之实现数组模拟队列及可复用环形队列详解
    队列简介 队列是一个有序列表,可以用数组或是链表来实现。 遵循先入先出的原则。即先存入队列的数据,先取出,后存入的后取出。 示意图:(使用数组模拟队列示意图) 有两个分别指向头部...
    99+
    2024-04-02
  • JAVA自定义注解详情
    目录原理:元注解:@Retention参数讲解:案例:给一个类的String属性设置默认值总结原理: 注解的本质是继承Annotation的特殊接口,其具体实现类是Java运行时生成...
    99+
    2024-04-02
  • Android自定义LocationMarker的实现详解
    目录自定义View LocationMarker应用自定义View到AMapView中今天讲一个比较简单的东西自定义绘制Marker 其实就是自定义view, 跟轨迹没太多关联,还有...
    99+
    2023-02-10
    Android自定义LocationMarker Android LocationMarker
  • Spring@Component自定义注解实现详解
    目录引子Java里的注解注解是什么元注解注解的保存策略自定义注解注解元素注解处理器注解是什么自己写一个@Component注解准备工作代码实现准备@MyComponent注解准备一个...
    99+
    2024-04-02
  • Java自定义注解的详解
    Java自定义注解Java注解提供了关于代码的一些信息,但并不直接作用于它所注解的代码内容。在这个教程当中,我们将学习Java的注解,如何定制注解,注解的使用以及如何通过反射解析注解。Java1.5引入了注解,当前许多java框架中大量使用...
    99+
    2023-05-31
    java 自定义 注解
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作