Java数据结构之单链表详解

 更新时间:2021年05月17日 11:26:37   作者:rain67  
在之前的学习中,我们主要了解了很多 Java 的 基本语法,但是在之后的 Java学习中,了解基础数据结构的知识非常重要,数据结构的思想可以帮助我们更加清晰明白的了解 Java 的解题思路等等.今天我们就来开始学习实现一个Java基础的单链表,需要的朋友可以参考下

一、图示

在这里插入图片描述

二、链表的概念及结构

链表是一种物理存储结构上非连续存储结构,数据元素的逻辑顺序是通过链表中的引用链接次序实现的 。

实际中链表的结构非常多样,以下情况组合起来就有8种链表结构:

单向、双向

带头、不带头

循环、非循环

今天,我们实现的是一个 单向 无头 非循环的链表。

下面是此链表的结构组成。

在这里插入图片描述

三、单链表的实现

(1)定义一个节点类型

我们创建一个 ListNode 的类作为节点类型,那么我们如何定义成员属性呢?

通过上面的结构分析,我们需要定义两个成员变量 val --作为该节点的存储的数值, next – 保存下一个节点的地址/引用。

同时定义之后,他们的默认值为 0 ,null ,所以要想赋予这个节点数值,要写一个构造方法去首先保存数值。

在这里插入图片描述

这里我们提供了两个构造方法,一个是实现提供数值的节点,另一个是没有提供数值的节点,方便我们之后使用。

之后我们在 MyListNode 的类中实现单链表的各种方法。

在这里插入图片描述

(2)头插法

在这里插入图片描述

以上述结构为例,这个单链表没有专门的傀儡节点来充当头节点,首个节点就定义为头节点,所以头插法,就是我们定义一个节点,插在这个链表的最前面,作为新的 head。

代码实现:

1.定义一个插入的节点

 ListNode cur = new ListNode(2);

在这里插入图片描述

此时我们就创建了一个val 为2 的节点。

2.插在头节点的前面

这里分两种情况,

第一次插入节点

不是第一次插入节点

头插之后的结构:

在这里插入图片描述

代码实现:

在这里插入图片描述

(3)尾插法

和头插法类似,同样插入一个节点,在链表的最后。

在这里插入图片描述

这里插入也分为两种情况

第一次插入节点

不是第一次插入节点

代码实现:

在这里插入图片描述

(4)根据下标插入节点

第一个数据节点为0号下标,任意位置插入节点。

还以上面的链表为例,我们想将新的节点插入到2 号位置

在这里插入图片描述

如果想插到2号位置,我们需要改变原来的 1号位置节点和2号位置节点的相关属性。

思路实现:

  1.先判断传入的 index 下标位置是否合法

  2.如果传入的index==0,头插法

  3.如果传入的index==sizeof(),尾插法

  4.如果 sizeof() > index > 0 在链表中间插入,我们首先要找到 index-1 位置的节点 prev

查找 index-1

在这里插入图片描述

修改 prev节点的属性 以及 新节点的属性

  node.next = prev.next
     prev.next = node;

代码实现过程

在这里插入图片描述

(5)查找关键字

在这里插入图片描述

以上面的链表为例,我们现在要查找这个链表中是否出现 val=20 的节点,如果存在,那么返回true,如果不存在,则返回 false.

遍历链表,走过每一个节点,如果 cur.val == key,则 return ture ,遍历完后还未找到 key,那么return false.

在这里插入图片描述

(6)删除第一次出现的关键字

在这里插入图片描述

思路实现:

在这里插入图片描述

代码实现:

在这里插入图片描述

(7)得到单链表的长度

在这里插入图片描述

(8)单链表打印展示

在这里插入图片描述

不能是this.head.next != null 这样写 最后一个节点是不能被打印的

(9)节点的回收

节点的回收有两种方式:

  1.暴力法

直接将head 置空

  2. 挨个置空

遍历单链表,将每一个节点的next都置为 null.

在这里插入图片描述

四、完整代码的展示

在这里插入图片描述

到此这篇关于Java数据结构之单链表详解的文章就介绍到这了,更多相关Java单链表内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • WebSocket+Vue+SpringBoot实现语音通话的使用示例

    WebSocket+Vue+SpringBoot实现语音通话的使用示例

    本文主要介绍了WebSocket+Vue+SpringBoot实现语音通话的使用示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-11-11
  • 详解SpringBoot Starter作用及原理

    详解SpringBoot Starter作用及原理

    大家都知道基于 SpringBoot 开发项目可以简化 Spring 应用的搭建以及开发过程,提高程序员开发效率,这是由于其“约定大约配置”的策略及其自动装配的特点,Starter 就是自动装配的具体实现,本文详细介绍了SpringBoot Starter作用及原理,欢迎大家来阅读学习
    2023-04-04
  • Springboot异常日志输出方式

    Springboot异常日志输出方式

    这篇文章主要介绍了Springboot异常日志输出方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • Java中的方法内联介绍

    Java中的方法内联介绍

    大家好,本篇文章主要讲的是Java中的方法内联介绍,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
    2022-01-01
  • java实现Z字形扫描程序

    java实现Z字形扫描程序

    这篇文章主要为大家详细介绍了java实现Z字形扫描程序,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-03-03
  • SpringBoot3安全管理操作方法

    SpringBoot3安全管理操作方法

    这篇文章主要介绍了SpringBoot3安全管理,在实际开发中,最常用的是登录验证和权限体系两大功能,在登录时完成身份的验证,加载相关信息和角色权限,在访问其他系统资源时,进行权限的验证,保护系统的安全,文中有详细的操作步骤,需要的朋友可以参考下
    2023-08-08
  • Java 大小写最快转换方式实例代码

    Java 大小写最快转换方式实例代码

    这篇文章主要介绍了Java 大小写最快转换方式实例代码的相关资料,需要的朋友可以参考下
    2017-07-07
  • 在Spring Boot中实现HTTP缓存的方法

    在Spring Boot中实现HTTP缓存的方法

    缓存是HTTP协议的一个强大功能,但由于某些原因,它主要用于静态资源,如图像,CSS样式表或JavaScript文件。本文重点给大家介绍在Spring Boot中实现HTTP缓存的方法,感兴趣的朋友跟随小编一起看看吧
    2018-10-10
  • 深入学习Hibernate持久化对象的三个状态

    深入学习Hibernate持久化对象的三个状态

    Hibernate中的对象有3中状态,瞬时对象(TransientObjects)、持久化对象(PersistentObjects)和离线对象(DetachedObjects也叫做脱管对象),下面通过本文给大家分享Hibernate持久化对象的三个状态,一起看看吧
    2017-09-09
  • 永中文档在线转换服务Swagger调用说明

    永中文档在线转换服务Swagger调用说明

    这篇文章主要为大家介绍了永中文档在线转换服务Swagger调用说明,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06

最新评论