【Java数据结构】详解LinkedList与链表(四)

🔒文章目录:

1.❤️❤️前言~🥳🎉🎉🎉

2.什么是LinkedList

3.LinkedList的使用

3.1LinkedList的构造方法

3.2LinkedList的其他常用方法介绍

addAll方法

subList方法

LinkedList的常用方法总使用

[3.3 LinkedList的遍历](#3.3 LinkedList的遍历)

println打印

for-each遍历

迭代器遍历

4.ArrayList和LinkedList的区别

5.总结


1.❤️❤️前言~🥳🎉🎉🎉

Hello, Hello~ 亲爱的朋友们👋👋,这里是E绵绵呀✍️✍️。

如果你喜欢这篇文章,请别吝啬你的点赞❤️❤️和收藏📖📖。如果你对我的内容感兴趣,记得关注我👀👀以便不错过每一篇精彩。

当然,如果在阅读中发现任何问题或疑问,我非常欢迎你在评论区留言指正🗨️🗨️。让我们共同努力,一起进步!

加油,一起CHIN UP!💪💪

🔗个人主页:E绵绵的博客**
📚所属专栏:**

1. JAVA知识点专栏

深入探索JAVA的核心概念与技术细节

2.JAVA题目练习****

实战演练,巩固JAVA编程技能

3.c语言知识点专栏****

揭示c语言的底层逻辑与高级特性

4.c语言题目练习****

挑战自我,提升c语言编程能力

📘 持续更新中,敬请期待 ❤️❤️

2.什么是LinkedList

LinkedList的底层是无头双向非循环链表结构, 由于链表没有将元素存储在连续的空间中,元素存储在单独的节点中,然后通过引用将节点连接起来了,因此在在任意位置插入或者删除元素时,不需要搬移元素,效率比较高。

3.LinkedList的使用

3.1LinkedList的构造方法

 public LinkedList() {
    }

这是第一个构造方法,在这个构造函数中,没有任何参数或代码,因此它的作用是创建一个空的链表对象。如果在创建LinkedList对象时不提供任何参数,那么就会默认调用这个构造函数。

public LinkedList(Collection<? extends E> c) {
        this();
        addAll(c);
    }

这是Java中LinkedList类的第二个构造函数。它接受一个集合作为参数,并将该集合的所有元素添加到新创建的LinkedList中。

构造函数的第一行this()调用了默认构造函数,它会创建一个空的LinkedList对象。然后,addAll方法将集合c中的元素全部添加到新创建的LinkedList对象中。

由于这个构造函数接受的是一个Collection类型的参数,因此可以传入任何实现了Collection接口的类的对象。

并且因为该构造函数还使用了<? extends E>,它表示传递给构造函数的集合c中的<元素类型>必须是E或E的子类。

3.2LinkedList的其他常用方法介绍

**这里我们重点讲两个方法:一个是addAll方法,另一个是subList方法。**其他方法都很简单,没必要讲。

addAll方法

addAll方法:

LinkedList中的addAll方法是将另一个集合c中的所有元素尾插到该对象中。

其中有以下要求:

参数c要求是实现了Collection接口的对象

传递给构造函数的集合c中的<元素类型>必须是E或E的子类。

subList方法

LinkedList中的subList方法用于获取原链表的一个子链表。它接受两个参数,分别是起始索引(fromindex)和结束索引(toindex),**其左闭右开。**一个新的List对象,包含原链表中指定范围内的元素。

subList方法返回的子链表在原链表的内部,对子链表的修改会反映到原链表上,反之亦然。

需要注意的是,如果有一个链表此时存在一个子链表,**现在将该链表结构性修改(如添加或删除元素),之后再用println打印子链表,会导致ConcurrentModificationException异常抛出。**这是因为结构性修改改变了原链表的大小,从而也破坏了其子链表的大小,所以打印子链表时就报错。(内容牵涉到了迭代器,这里就不细讲)

LinkedList的常用方法总使用

public class Test {
    public static void main(String[] args) {
        LinkedList<String>  linkedList=new LinkedList<>();
         linkedList.add("hello");
         linkedList.add(0,"world");
         linkedList.add(0,"Are");
        System.out.println(linkedList);
        System.out.println(linkedList.get(0));
        linkedList.set(2,"am");
          linkedList.remove(0);
          linkedList.remove("world");
        System.out.println(linkedList);
        System.out.println(linkedList.contains("am"));
        linkedList.add("sit");
        linkedList.add("am");
        System.out.println(linkedList.lastIndexOf("am"));
        System.out.println(linkedList.indexOf("am"));
        System.out.println(linkedList);
       List<String> list=linkedList.subList(0,2);
       linkedList.set(0,"she");
        System.out.println(list);
        linkedList.clear();
        System.out.println(linkedList);
}}

3.3 LinkedList的遍历

println打印

由上图可知我们的ArrayList的父类重写了toString方法。所以我们可以用println打印出该LinkedList对象内部的所有元素,以字符串形式打印出来。

例如,如果LinkedList对象中有三个元素 "apple"、"banana" 和 "orange",那么调用println方法将打印出字符串 "[apple, banana, orange]"。

for-each遍历

在这先提前说个知识点,for-each循环适用于数组, collection类及collection的子类。

所以我们可以用它遍历LinkedLIst类,(LinkedList类是Collection的子类)。注意我们是从下标0开始遍历。

   LinkedList<String> linkedList1=new LinkedList<>();
        linkedList1.add("hello");
        linkedList1.add("hel");
        linkedList1.add("he");
        linkedList1.add("hell");
        for ( String s: linkedList1) {
            System.out.print(s+"  ");
        }

ArrayList(顺序表)也是同理可以用for-each进行遍历,顺序表文章中已经讲过该点。

迭代器遍历

对于迭代器遍历我们现在还没学到迭代器,所以只需要记住代码就ok了,不用知道原理。

使 用 迭 代 器 遍 历 - - - 正 向 遍 历

LinkedList<String> linkedList2=new LinkedList<>();
        linkedList2.add("hello");
        linkedList2.add("hel");
        linkedList2.add("he");
        linkedList2.add("hell");
        ListIterator<String> it=linkedList2.listIterator();
        while(it.hasNext()) {
            System.out.print(it.next() + " ");
        }


使 用 反 向 迭 代 器 - - - 反 向 遍 历

LinkedList<String> linkedList2=new LinkedList<>();
        linkedList2.add("hello");
        linkedList2.add("hel");
        linkedList2.add("he");
        linkedList2.add("hell");
        ListIterator<String> it=linkedList2.listIterator(linkedList2.size());
        while(it.hasPrevious()) {
            System.out.print(it.previous() + " ");
        }

4.ArrayList和LinkedList的区别



两者的区别如上图所示,这里就不再多说了。

5.总结

所以我们的链表篇章现在就正式结束啦!下篇将给大家带来栈和队列的介绍。 在此,我们诚挚地邀请各位大佬们为我们点赞、关注,并在评论区留下您宝贵的意见与建议。让我们共同学习,共同进步,为知识的海洋增添更多宝贵的财富!🎉🎉🎉❤️❤️💕💕🥳👏👏👏

相关推荐
孤寂码农_defector3 分钟前
C++清除所有输出【DEV-C++】所有编辑器通用 | 算法基础NO.1
数据结构·c++·算法·编辑器
八宝袋7 分钟前
设计模式之工厂模式,但是宝可梦
java·设计模式·工厂模式
一支榴莲挞10 分钟前
前后端分离练习(云客项目)
java·vue.js·spring boot·前端框架
oioihoii10 分钟前
设计模式概述
java·c++·设计模式·面试·c#·大学必学
菜喵一只21 分钟前
计算2的N次方
数据结构·算法
清灵xmf37 分钟前
为什么 Vue3 封装 Table 组件丢失 expose 方法呢?
开发语言·前端·javascript·封装·eltable
神仙别闹1 小时前
基于JAVA实现的(GUI)坦克大战游戏
java·开发语言·游戏
凡人的AI工具箱1 小时前
15分钟学 Go 第 54 天 :项目总结与经验分享
开发语言·人工智能·后端·算法·golang
小春学渗透1 小时前
DAY110代码审计-PHP框架开发篇&ThinkPHP&版本缺陷&不安全写法&路由访问&利用链
开发语言·安全·web安全·php
R-sz1 小时前
java如何利用流式计算筛选出同一天时间最新的一条数据
java·windows·python