Java数据结构—链表与LinkedList

  在学习完ArrayList之后我们知道其底层是数组,我们变为ArrayList这个类后可以对其底层的数组进行增删查改的操作,但也由于ArrayList的底层是数组,这也使得我们在增加或者删除ArrayList中的数据的时候时间复杂度会变的很慢,并且过程中占到了很大的内存空间,ArrayList进行这些操作是不够快且空间也不够小的。

  所以,当我们只需要对一串数据进行查询的时候,用ArrayList比较适合,而作为其他的删改增是不大适用的,这个时候就需要我们学习一个新的数据结构——链表😎


🌱链表

🌿链表的结构

  链表是由一个个的节点链接而成的,而节点里面包含数值域next域。我们可以将链表想象成火车,数值域就是车厢,而next域就是链接下一节车厢的链接链。图示如下👇

 

 整条链表的大致图示如下👇

  链表又分为单向或双向、循环或非循环、带头或不带头的链表,我们拿其中两个来做图示,相信大家就能理解这几个不同的链表是怎么回事了😎


🌱链表实战部分

  链表的内容其实不多,主要是要我们多写LeetCode题目,在这里博主推荐在LeetCode上面写题目,例如反转一个单链表链表的回文结构等题目都是很好的,在这里博主有写一些有关链表的题目,都是博主认为不错的题目~感兴趣的小伙伴可以看一下😎


🌱LinkedList

LinkedList是java中提供的一种类,其本质是双向链表,拥有前驱和后继。

由于LinkedList继承了多个接口,所以LinkedList也可以当作栈、队列、链表来使用


以上!便是全部的啦😎

又是收获满满的一天~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
链表是一种常见的数据结构,用于存储一系列的元素。在Java中,链表可以使用LinkedList类来实现。下面是关于Java链表的详细解释: 链表由节点(Node)组成,每个节点包含两部分:数据域(存储元素的值)和指针域(指向下一个节点的指针)。链表的头节点是链表的起始点,尾节点是链表的结束点。 Java中的LinkedList类实现了List接口和Deque接口,因此可以用作列表和双端队列。LinkedList在内存中以链式结构存储元素,相邻元素通过节点的指针连接。 与数组相比,链表的一个优势是可以快速地插入和删除元素。由于链表中的元素在内存中不连续存储,所以插入和删除只需要改变指针的指向,而不需要移动其他元素。然而,链表的一个劣势是访问特定索引的元素比较慢,因为需要从头节点开始遍历链表。 下面是一些常用的操作示例: 1. 创建一个空链表LinkedList<String> list = new LinkedList<>(); 2. 在链表末尾添加元素: list.add("A"); list.add("B"); list.add("C"); 3. 在指定位置插入元素: list.add(1, "D"); // 在索引为1的位置插入元素D 4. 获取链表的大小: int size = list.size(); 5. 获取指定索引位置的元素: String element = list.get(2); // 获取索引为2的元素 6. 修改指定索引位置的元素: list.set(0, "E"); // 将索引为0的元素修改为E 7. 删除指定索引位置的元素: list.remove(1); // 删除索引为1的元素 8. 遍历链表: for (String element : list) { System.out.println(element); } 需要注意的是,LinkedList类不是线程安全的,如果在多线程环境中使用链表,需要进行适当的同步处理。此外,由于链表中的元素不是连续存储,所以对于大量元素的访问和操作,可能会导致性能下降。在这种情况下,可以考虑使用ArrayList或其他更适合的数据结构

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值