Java常用API之LinkedList类解读

写在开头:本文用于作者学习我将官方文档中LinkedList 1.6版本中类中绝大部分API全测了一遍并打印了结果,日拱一卒,常看常新。

自己补充了一些对该数据结构的理解,如有不对的地方,请各位指正,谢谢。

首先,LinkedList是一个链表结构,往它里面添加数据的时候,它会自动帮你记录每个元素的位置,记载它的nex(指针)t里面。

相比数组而言,它就像一个有很多节的火车(装载量可变),数组有点像货车(装载量不可变),可以通过如下代码定义一个简单的链表结构

补充:定义单向链表的节点类

class ListNode {//定义链表结构,属性一int value记录值(载重),ListNode next记录下一节点(车厢)的位置
    int val;//数据域
    ListNode next;//指针域, next表示指针,表示下一个节点是谁
}

它里面有两个属性要被定义,一个是数据域,用来存链表中的数据;一个是指针域,用来指向它下一个节点的内存地址。

先定义双向链表的节点类

public class Node {//定义节点类
    int data;
    Node prev;//指向前一个位置
    Node next;//后一个位置

    public Node(int data) {//构造函数
        this.data = data;
        this.prev = null;
        this.next = null;
    }
}

再定义个双向链表类

public class DoublyLinkedList {
    Node head;//head变量类型为Node类,前面定义节点类就为了这,用于存储链表头节点的引用

    public DoublyLinkedList() {
        this.head = null;
    }

    // 添加元素到链表末尾
    public void add(int data) {
        Node newNode = new Node(data);
        if (head == null) {
            head = newNode;// 如果链表为空,新节点成为头节点
        } else {//如果链表不为空
            Node current = head;// 将头节点先赋给当前节点
            while (current.next != null) {//再判断当前节点的下一个索引是否为空,不为空继续遍历
                current = current.next;//直到当前节点的下个索引指向空,退出循环
            }
            current.next = newNode;//将当前节点索引指向新节点
            newNode.prev = current;//将新节点的上一个索引指向当前节点
        }
    }

    // 删除指定元素
    public void remove(int data) {
        if (head == null) return;

        Node current = head;
        while (current != null) {
            if (current.data == data) {
                if (current.prev != null) {
                    current.prev.next = current.next;
                } else {
                    head = current.next;
                }
                if (current.next != null) {
                    current.next.prev = current.prev;
                }
                return;
            }
            current = current.next;
        }
    }

    // 打印链表
    public void printList() {
        Node current = head;
        while (current != null) {
            System.out.print(current.data + " ");
            current = current.next;
        }
        System.out.println();
    }

    public static void main(String[] args) {
        DoublyLinkedList dll = new DoublyLinkedList();
        dll.add(10);
        dll.add(20);
        dll.add(30);
        dll.printList();  // 打印: 10 20 30

        dll.remove(20);
        dll.printList();  // 打印: 10 30
    }
}

下面是一些它的方法:

add() 末尾添加元素

@Test
    public void test_add(){
        // 将指定元素添加到此列表的结尾
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
        }};
        System.out.println(a);//[a]
    }

addIndex() 指定索引添加元素

@Test
    public void test_addIndex(){
        //在此列表中指定的位置插入指定的元素
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            add(0,'b');
        }};

        System.out.println(a);//[b, a]
    }

addAll() 往里加一个集合

@Test
    public void test_addAll(){
        // 添加指定 collection 中的所有元素到此列表的结尾,顺序是指定 collection 的迭代器返回这些元素的顺序
        LinkedList<Character> b = new LinkedList<Character>() {{
            add('^');
        }};

        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            add(0,'b');

            addAll(b);
        }};

        System.out.println(a);//[b, a, ^]
    }

addFirst() 头位置添加

@Test
    public void test_addFirst(){
        //将指定元素插入此列表的开头
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            addFirst('c');
        }};

        System.out.println(a);//[c, a]
    }

addLast() 末尾添加

@Test
    public void test_addLast(){
        //将指定元素添加到此列表的结尾
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            addLast('d');
        }};

        System.out.println(a);//[a, d]
    }

clear()

@Test
    public void test_clear(){
        //从此列表中移除所有元素
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            addLast('d');
        }};

        a.clear();
        System.out.println(a);//[]
    }

clone()

@Test
    public void test_clone(){
        //返回此 LinkedList 的浅表副本
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            addLast('d');
        }};

        Object clone = a.clone();
        System.out.println(clone);//[a, d]
    }

contains() 是否包含

@Test
    public void test_contains(){
        //如果此列表包含指定元素,则返回 true
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            addLast('d');
        }};

        boolean a1 = a.contains('a');
        System.out.println(a1);//true
    }

element() 获取但不移除头元素

@Test
    public void test_element(){
        //获取但不移除此列表的头(第一个元素)。
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            addLast('d');
        }};

        Character element = a.element();
        System.out.println(element);//a
        System.out.println(a);//[a, d]
    }

get() 按索引取值

@Test
    public void test_get(){
        //获取但不移除此列表的头(第一个元素)。
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            addLast('d');
        }};

        Character character = a.get(1);
        System.out.println(character);//d
    }

getFirst()

@Test
    public void test_getFirst(){
        //获取但不移除此列表的头(第一个元素)。
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            addLast('d');
        }};

        Character first = a.getFirst();
        System.out.println(first);//a
    }

getLast()

@Test
    public void test_getLast(){
        //获取但不移除此列表的头(第一个元素)。
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            addLast('d');
        }};

        Character last = a.getLast();
        System.out.println(last);//d
    }

indexOf() 按值取索引

@Test
    public void test_indexOf(){
        //返回此列表中首次出现的指定元素的索引,如果此列表中不包含该元素,则返回 -1。
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            addLast('d');
        }};

        int index = a.indexOf('a');
        System.out.println(index);//0
    }

lastIndexOf() 最后位置出现的索引

@Test
    public void test_lastIndexOf(){
        //返回此列表中最后出现的指定元素的索引,如果此列表中不包含该元素,则返回 -1
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            addLast('d');
        }};

        int index = a.lastIndexOf('a');
        System.out.println(index);//0
    }

listIterator() 迭代器

@Test
    public void test_listIterator(){
        //返回此列表中的元素的列表迭代器(按适当顺序),从列表中指定位置开始
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            addLast('d');
        }};

        ListIterator<Character> iterator = a.listIterator(1);
        if(iterator.hasNext()){
            System.out.println(iterator.next());//d
        }
    }

peek() 取第一个

@Test
    public void test_peek(){
        //获取但不移除此列表的头(第一个元素
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            add('b');
            addLast('d');
        }};

        Character peek = a.peek();
        System.out.println(peek);//a
    }

poll() 取第一个

@Test
    public void test_poll(){
        //获取并移除此列表的头(第一个元素)
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            add('b');
            addLast('d');
        }};

        Character poll = a.poll();
        System.out.println(a);//[b, d]
    }

pop() 取第一个

@Test
    public void test_pop(){
        //从此列表所表示的堆栈处弹出一个元素
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            add('b');
            addLast('d');
        }};

        Character pop = a.pop();
        System.out.println(pop);//a
        System.out.println(a);//[b, d]
    }

remove() 移除指定索引元素

@Test
    public void test_remove(){
        // 移除此列表中指定位置处的元素
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            add('b');
            addLast('d');
        }};

        a.remove(1);
        System.out.println(a);//[a, d]
    }

removeFirst() 移除第一个

@Test
    public void test_removeFirst(){
        //移除并返回此列表的第一个元素
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            addLast('d');
        }};

        Character character = a.removeFirst();
        System.out.println(character);//a
    }

removeLast() 移除最后一个

@Test
    public void test_removeLast(){
        //移除并返回此列表的最后一个元素
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            addLast('d');
        }};

        Character character = a.removeLast();
        System.out.println(character);//d
    }

set() 赋值

@Test
    public void test_set(){
        //将此列表中指定位置的元素替换为指定的元素
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            addLast('d');
        }};

        Character e = a.set(1, 'e');
        // Character e1 = a.set(2, 'e');越界了
        System.out.println(a);//[a, e]
    }

size() 取大小

@Test
    public void test_size(){
        //将此列表中指定位置的元素替换为指定的元素
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            addLast('d');
        }};

        System.out.println(a.size());//2
    }

toArray() 转数组

@Test
    public void test_toArray(){
        //返回以适当顺序(从第一个元素到最后一个元素)包含此列表中所有元素的数组
        LinkedList<Character> a = new LinkedList<Character>() {{
            add('a');
            addLast('d');
        }};

        Object[] objects = a.toArray();
        System.out.println(objects[1]);//d

    }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/591539.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

QT5之事件——包含提升控件

事件概述 信号就是事件的一种&#xff0c;事件由用户触发&#xff1b; 鼠标点击窗口&#xff0c;也可以检测到事件&#xff1b;产生事件后&#xff0c;传给事件处理&#xff0c;判断事件类型&#xff0c;后执行事件相应函数&#xff1b; 类似单片机的中断&#xff08;中断向量…

C语言 联合和枚举

目录 1. 联合体1.1 联合体类型的声明1.2 联合体变量的创建1.3 联合体的特点1.4 联合体在内存中的存储1.5 联合体使用举例 2. 枚举类型2.1 枚举类型的声明2.2 枚举变量的创建和初始化2.3 枚举类型的大小2.4 枚举类型的优点 正文开始 上次我们通过《C语言 结构体详解》学习了结构…

基于SpringBoot的饭店外卖平台的设计与实现

项目描述 这是一款基于SpringBoot的饭店外卖平台的系统 模块描述 用户端 登录 首页 商家信息 点餐 菜品列表 下单 订单列表 账号下单列表 个人中心 个人资料 修改信息 评论管理 评论菜品 查看评论 打赏骑手 打赏骑手 管理员 登录 菜品管理 修改 下架 订单列表 下单记录 菜品管理…

领域驱动设计(DDD)笔记(一)基本概念

文章链接 领域驱动设计&#xff08;DDD&#xff09;笔记&#xff08;一&#xff09;基本概念-CSDN博客领域驱动设计&#xff08;DDD&#xff09;笔记&#xff08;二&#xff09;代码组织原则-CSDN博客领域驱动设计&#xff08;DDD&#xff09;笔记&#xff08;三&#xff09;后…

C#知识|事件集中响应,多个按钮关联同一事件(实例练习)

哈喽&#xff0c;你好&#xff0c;我是雷工&#xff01; 本节学习窗体Controls集合、控件事件的统一关联及如何优化重复代码。 01 事件集中响应 原理&#xff1a;就是相同的控件&#xff0c;可以关联同一个事件响应方法。 02 示例演示 2.1、示例功能 该示例实现窗体中选择…

光伏光热热泵系统(PVT)介绍

伏光热PVT热泵是一种主动利用太阳辐射能的有效方式&#xff0c;其不仅能够进行光伏发电&#xff0c;还能够利用少量的电能提高热能的品位。太阳能PVT热泵除具有发电和制热的功能外&#xff0c;还可以制冷&#xff0c;其产生的冷能可用于夏季建筑室内温度的调节。 与此同时&…

STM32单片机wifi云平台+温度+烟雾+火焰+短信+蜂鸣器 源程序原理图

目录 1. 整体设计 2. 液晶显示 3. Ds18b20温度传感器 4. Mq2烟雾传感器 5. 火焰传感器传感器 6. 蜂鸣器驱动控制 7. 按键 8. Gsm短信模块 9. Esp8266wifi模块 10、源代码 11、资料内容 资料下载地址&#xff1a;STM32单片机wi…

Adobe-Premiere-CEP 扩展 入门-视频剪辑-去气口插件-Silence Remover

短视频&#xff0c;这两年比较火&#xff0c;不要再问为什么用Premiere&#xff0c;非常难用&#xff0c;为什么不用某影&#xff0c;某些国内软件非常接地气简单&#xff0c;又例如某音资深的视频短编辑就很好用了。。。 Premiere二次开发调试难&#xff0c;不如自己搞个cons…

展开说说:Android Fragment完全解析-卷三

本文章分析了Fragment的管理器FragmentManager、事务FragmentTransaction 、以及完整的声明周期和动态加载Fragment的原理解析。 1、Fragment管理器 FragmentManager 类负责在应用的 fragment 上执行一些操作&#xff0c;如添加、移除或替换操作&#xff0c;以及将操作添加到…

介绍BCD码

BCD码&#xff08;Binary-Coded Decimal‎&#xff09;&#xff0c;用4位 二进制数 来表示1位 十进制数 中的0~9这10个数码&#xff0c;是一种二进制的数字编码形式&#xff0c;用 二进制编码的十进制 代码。 BCD码这种编码形式利用了四个位元来储存一个十进制的数码&#xff0…

关于莫比乌斯变换属性梳理

文章目录 一、说明二、多视角看莫比乌斯变换2.1 从几何角度2.2 复分析中的莫比乌斯变换2.3 莫比乌斯变换运算组合2.4 莫比乌斯变换的不动点2.5 三个点决定一个莫比乌斯变换2.6 交叉比2.7 莫比乌斯变换的逆变换 三 莫比乌斯变换性质证明3.1 证明1&#xff1a;莫比乌斯变换将圆变…

最新SpringBoot项目地方废物回收机构管理系统

采用技术 最新SpringBoot项目地方废物回收机构管理系统的设计与实现~ 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;SpringBootMyBatis 工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 页面展示效果 登录页面 后端管理员 管理员首页 员工管理 设…

微星主板安装双系统不能进入Ubuntu的解决办法

在微星主板的台式机上面依次安装了Windows11和Ubuntu22.04。在Ubuntu安装完成后重启&#xff0c;没有出现系统选择界面&#xff0c;直接进入了Windows11。怎么解决&#xff1f;方法如下&#xff1a; &#xff08;1&#xff09;正常安装Windows11 &#xff08;2&#xff09;安…

基于php+mysql+html简单图书管理系统

博主介绍&#xff1a; 大家好&#xff0c;本人精通Java、Python、Php、C#、C、C编程语言&#xff0c;同时也熟练掌握微信小程序、Android等技术&#xff0c;能够为大家提供全方位的技术支持和交流。 我有丰富的成品Java、Python、C#毕设项目经验&#xff0c;能够为学生提供各类…

需求规格说明书编制书(word原件)

1 范围 1.1 系统概述 1.2 文档概述 1.3 术语及缩略语 2 引用文档 3 需求 3.1 要求的状态和方式 3.2 系统能力需求 3.3 系统外部接口需求 3.3.1 管理接口 3.3.2 业务接口 3.4 系统内部接口需求 3.5 系统内部数据需求 3.6 适应性需求 3.7 安全性需求 3.8 保密性需…

# IDEA 复制项目 Module 出现 不同模块下的 Product 类报错

IDEA 复制项目 Module 出现 不同模块下的 Product 类报错 我们 用 IDEA 复制项目 Module 出现 不同模块下的 Product 类报错&#xff0c;发现复制的 module 名称没有改变或者 java 文件夹后面还有原项目 source root 字样&#xff0c;maven 父子项目没有标识等问题。 解决方法…

二叉树四种遍历方法

目录 树基本概念 二叉树二叉树的五种形态特殊二叉树二叉链表创建四种遍历方法代码实现 树 树是一个n个节点的有限集&#xff0c;当n0时称之为空树 基本概念 性质 1. 树的定义是递归的&#xff0c;树的定义中又用到了自身 2. 树的根节点没有前驱&#xff0c;除根结点外&#x…

开了个新店!

大家好&#xff0c;我是麦鸽。 一言难尽&#xff0c;五一之前&#xff0c;把大A里的钱都提出来了&#xff0c;又整了一个新的小店。熟悉我的老读者应该都知道&#xff0c;我主业是做嵌入式的&#xff0c;后面慢慢转了技术管理的路线。平时也搞点副业&#xff0c;餐饮店就是其中…

关于链表带环问题为什么要用快慢指针

判断链表是否带环 题目描述 给你一个链表的头节点 head &#xff0c;判断链表中是否有环。 如果链表中有某个节点&#xff0c;可以通过连续跟踪 next 指针再次到达&#xff0c;则链表中存在环。 为了表示给定链表中的环&#xff0c;评测系统内部使用整数 pos 来表示链表尾连…

定制开发AI名片商城AI导购系统:引领营销自动化的新时代

在数字营销日新月异的今天&#xff0c;一个革命性的工具——定制开发AI名片商城AI导购系统&#xff0c;正逐渐崭露头角&#xff0c;成为企业私域运营中的得力助手。它不仅仅是一个营销工具&#xff0c;更是一个拥有强大营销自动化能力和先进算法技术的在线助理&#xff0c;为企…
最新文章