LinkedList与链表

目录

1、链表

2、实现自己的链表 (不带头结点)

2.1、遍历链表

2.2、求链表长度

2.3、判断链表是否包含关键字

2.4、插入节点

2.5、任意位置插入一个节点

2.6、删除一个节点

2.7、删除所有值为key的节点

2.8、清空所有节点


1、链表

链表是一种物理结构上不连续的存储结构,数据元素的逻辑顺序是通过链表中的引用链接次序实现的;类似火车车厢,链表是由一个一个的节点组成的

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

  1. 单向或者双向
  1. 带头或者不带头
  1. 循环或者非循环

2、实现自己的链表 (不带头结点)

创建一个 IList 接口,其中方法如下:

再创建一个 MySingleList 类,实现 IList 接口并重写其中的所有方法:

在 MySingleList 类中创建一个内部类 ListNode,表示节点,节点中包含数据域和next域;这里使用静态内部类,因为静态内部类对象不需要通过外部类对象的引用获得

2.1、遍历链表

display方法:

  1. 怎么从一个节点走到下一个节点的 ?

head = head.next;

  1. 怎么判断所有的节点都遍历完了 ?

head = null;

但是这样写会导致 head 变为 null ,所以让 cur 代替 head,避免 head 变为 null

从指定位置打印

2.2、求链表长度

size方法:

遍历每一个节点

2.3、判断链表是否包含关键字

contains方法:

2.4、插入节点

头插法:addFirst方法

  1. 实例化一个节点

  2. 改变插入节点的next

  3. 改变head

也可以直接这样写

^

尾插法:指的是讲待插入的节点存放在链表的最后一个位置

addLast方法:

  1. 实例化一个节点

  2. 找到最后一个节点cur

  3. cur.next = node;

分析:

  • 头插法的时间复杂度O(1)
  • 尾插法的时间复杂度O(N)

根据上述代码看出,链表的插入只需要改变指向就可以了!
结论:

  1. 如果想让 cur 停在最后一个节点的位置 -> cur.next!= null

  2. 如果想把整个链表的每个节点都遍历完 -> cur!= null

2.5、任意位置插入一个节点

addIndex方法:

  1. 让cur走index-1步

  2. node.next = cur.next;

cur.next = node;

在插入一个节点的时候,一定要先绑定后面的节点

2.6、删除一个节点

2.7、删除所有值为key的节点

2.8、清空所有节点

相关推荐
IT瘾君3 分钟前
Java基础:Logback日志框架
java·开发语言·logback
suimeng64 分钟前
Java的Selenium的特殊元素操作与定位之select下拉框
java·自动化测试·selenium
丶Darling.5 分钟前
26考研 | 王道 | 数据结构 | 第五章 树
数据结构·考研
ChinaRainbowSea16 分钟前
8. RabbitMQ 消息队列 + 结合配合 Spring Boot 框架实现 “发布确认” 的功能
java·spring boot·分布式·后端·rabbitmq·java-rabbitmq
、BeYourself32 分钟前
Sentinel[超详细讲解]-7 -之 -熔断降级[异常比例阈值]
java·spring cloud·sentinel
可乐加.糖42 分钟前
腾讯云K8s容器部署SpringBoot项目实现方案
java·spring boot·容器·kubernetes·k8s·腾讯云
不断前进的皮卡丘1 小时前
06-公寓租赁项目-后台管理-公寓管理篇
java·开发语言·数据库·spring boot
luoluoal1 小时前
Java项目之基于ssm的个性化旅游攻略定制系统(源码+文档)
java·mysql·mybatis·ssm·源码
永无魇足1 小时前
JAVASE(十五)正则表达式
java
天狼12221 小时前
java 正则表达式优化
java·mysql·正则表达式