数据结构 | LinkedList与链表

news2024/9/25 16:28:17

前言

  • ArrayList底层使用连续的空间,任意位置(尤其是0位置下标)插入或删除元素时,需要将该位置后序元素 整体 往前或往后搬移,故时间复杂度为O(N). 优点(给定一个下标,可以快速查找到对应的元素,时间复杂度为O(1))
  • 增容需要申请新空间,拷贝数据,释放旧空间,会有不小的消耗.
  • 增容一般是呈2倍的增长,势必有一定的空间浪费.例如当前容量为100,满了要扩容到200,当我们再插入5个数据,后面没有数据插入了,那么就浪费了95个数据空间.

那么此时,我们就思考,有没有一种数据结构,可以随用随取,插入/删除数据可以不移动元素?👉👉 

于此Java集合中又引入了链表结构.

链表的概念及结构

概念

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

生活中,火车是由许许多多的 车厢 组成 ;在链表中,则是由许多的 节点 组成.

        

  • 每一个节点都有地址. 是一个对象 ; null表示 不指向任何一个对象.
  • 第一个节点叫做 头节点head.可以认为head就是一个变量,该变量里面存了节点的地址. head是一个引用,这个引用指向个节点对象,就可以把链表里所有的元素都遍历.

结构 

组合一下有以下八种,但我们只需重点掌握 单向不带头非循环双向不带头非循环 结构.

 链表的实现

创建LinkedList类 实现IList接口

//模拟实现LinkedList链表
public class MySingleLinkedList implements IList {

    //定义一个静态内部类 --节点
    static class LinkedNode {
        public int value;//数值域
        public LinkedNode next;//next域 存放的是节点的地址

        public LinkedNode(int value) {
            this.value = value;
        }
    }
    public LinkedNode head;//head是 链表的头节点 null

    public void createList() {
        LinkedNode node1 = new LinkedNode(12);
        LinkedNode node2 = new LinkedNode(23);
        LinkedNode node3 = new LinkedNode(34);
        LinkedNode node4 = new LinkedNode(45);
        node1.next = node2;//表示node1的下一个节点是node2 node2这个引用存储了地址
        node2.next = node3;
        node3.next = node4;
        this.head = node1;//head指向了第一个节点的地址
    }

     @Override
    public void display() {
        LinkedNode cur = head;//定义临时变量
        while(cur != null) {   //当头节点为null时 算把所有节点都遍历完了
            System.out.print(cur.value + " ");
            cur = cur.next;//从第一个节点走到下一个节点
        }
    }

     @Override
    public int size() {   //计算有多少个节点
        int count = 0;
        LinkedNode cur = head;
        while(cur != null) {
            count ++;
            cur = cur.next;
        }
        return count;
    }

}
public interface IList {
        void addFirst(int data);
        void addLast(int data);
        void addIndex(int index,int data);
        boolean contains(int key);
        void remove(int key);
        void removeAllKey(int key);
        int size();
        void clear();
        void display();
}

解析

  •                 
  1. 在构造方法中,为什么不初始化next域? 是因为,当我们去插入一个节点时,首先要实例化该节点,但在构造完成这个节点之后,不知道这个next会是谁,所以next域的值应该为null.
  2. head是链表的头节点.是链表的属性,不是节点的节点.   初始值也为null.
  •     
  1. 实例化了四个节点的对象.
  2. node1的下一个节点是node2 , 用代码表示为 node1.next = node2; 同时node2这个引用变量存储的是0x987.
  3. this.head = node1; 表示 head 指向了第一个节点的地址
  •   
  1. head = head.next ; 从第一个节点走到 下一个节点.
  2. head = null ; 当head头节点为null时表示所有节点都被遍历了.
  3. 定义临时变量cur , 当遍历完后 head = null了就不指定头节点的位置了,我们希望的是 能够找到头节点的位置使得head始终指向第一个节点.
  4. 插入数据的时候 一定要先绑后面(该节点的下一个)的,因为可以通过遍历节点找到所有的节点 ; 而先把 头节点head这个引用指向该节点本身 , 再把该节点下一个指向head就找不到了,因为所指的是本身,后面的数据丢失了..

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux进程——环境变量之二

文章目录 环境变量查看环境变量获取环境变量main()的第三个参数本地变量全局环境变量内建命令与常规命令 环境变量 查看环境变量 在上一篇文章中我们只说了查看某个环境变量的值,那么如何查看所有的环境变量呢 使用指令env即可 例如 这里我们也不需要全部记住&a…

FastAPI(七十四)实战开发《在线课程学习系统》接口开发-- 删除留言

源码见:"fastapi_study_road-learning_system_online_courses: fastapi框架实战之--在线课程学习系统" 之前文章FastAPI(七十三)实战开发《在线课程学习系统》接口开发-- 回复留言,那么我们这次分享删除留言接口的开发…

从0开始的STM32HAL库学习9

定时器输入捕获测频率 生成待测信号 配置环境 选择如上图所示 代码修改 在main函数中加入 HAL_TIM_PWM_Start(&htim2,TIM_CHANNEL_1); 测量信号频率 配置环境 如图所示打开TIM3定时器 1. 设置TI1FP1为ResetMode,即清空计数 2. 使用内部时钟 3. 通道 1 设置为输…

手机怎么设置不同的ip地址

在数字化日益深入的今天,智能手机已成为我们生活、工作和学习中不可或缺的设备。然而,随着网络应用的广泛和深入,我们有时需要为手机设置不同的IP地址来满足特定需求。比如,避免网络限制、提高网络安全、或者进行网络测试等。本文…

tarojs项目启动篇

TaroJS 是一个开放式跨端开发解决方案,使用 React 语法规范来开发多端应用(包括小程序、H5、React Native 等)。它可以帮助开发者高效地构建出在不同端上运行一致的应用。以下是启动 TaroJS 项目(本来就有的旧项目)的步…

经典文献阅读之--LIV-GaussMap(实时3D辐射场地图渲染的LiDAR惯性视觉融合算法)

Tip: 如果你在进行深度学习、自动驾驶、模型推理、微调或AI绘画出图等任务,并且需要GPU资源,可以考虑使用UCloud云计算旗下的Compshare的GPU算力云平台。他们提供高性价比的4090 GPU,按时收费每卡2.6元,月卡只需要1.7元每小时&…

一文总结代理:代理模式、代理服务器

概述 代理在计算机编程领域,是一个很通用的概念,包括:代理设计模式,代理服务器等。 代理类持有具体实现类的实例,将在代理类上的操作转化为实例上方法的调用。为某个对象提供一个代理,以控制对这个对象的…

Haproxy 下载、编译部署、使用

文章目录 前言Haproxy 下载、编译部署、使用1. 下载2. 编译部署3. 使用3.1. 验证配置文件3.2. 启动 HAProxy 并指定配置文件路径3.3. 关闭HAProxy3.4. 重载HAProxy 3. 测试 前言 如果您觉得有用的话,记得给博主点个赞,评论,收藏一键三连啊&am…

go-kratos 学习笔记(7) 服务发现服务间通信grpc调用

服务发现 Registry 接口分为两个,Registrar 为实例注册和反注册,Discovery 为服务实例列表获取 创建一个 Discoverer 服务间的通信使用的grpc,放到data层,实现的是从uses服务调用orders服务 app/users/internal/data.go 加入 New…

可见性::

目录 定义: 解决方法: ①使用synchronized实现缓存和内存的同步 修改一: 加入语句: 代码: 修改2: 在代码块中加入: 代码: 执行结果: 原因: ②使用…

数字经济赋能爱疆事业:同疆共创,打造疆品出疆新通道

在数字化浪潮的推动下,新疆吐鲁番地区正迎来一场前所未有的变革。近日,由同疆共创公司承办的“品牌新力量,助农电商直播行,音乐嘉年华吐鲁番活动”在吐鲁番市火热开展,这一创新举措不仅彰显了同疆共创积极履行社会责任…

【redis】一致性hash算法和hash槽

普通hash取模 直接hash(key)%N , N为机器的数量,但不利于集器扩容或者缩容 一致性hash算法和hash槽 一致性hash算法是在redis 分片中使用,hash槽在redis cluster(集群)中使用 Redis一致性hash:Redis一致性hash是为…

AvaloniaUI的学习

相关网站 github:https://github.com/AvaloniaUI/Avalonia 官方中文文档:https://docs.avaloniaui.net/zh-Hans/docs/welcome IDE选择 VS2022VSCodeRider 以上三种我都尝试过,体验Rider最好。VS2022的提示功能不好,VSCode太慢&#xff0c…

Typora笔记上传到CSDN

1.Typora 安装 Typora链接:百度网盘 提取码:b6d1 旧版本是不需要破解的 后来的版本比如1.5.9把放在typora的根目录下就可以了 2.上传到CSDN 步骤 csdn 写文章-使用MD编辑器-导入本地md文件即可 问题 图片没法显示 原因 图片的链接是本地的 当然没法…

PySide(PyQt)使用QPropertyAnimation制作动态界面

主脚本: # encoding: utf-8 import os import sysfrom PySide6.QtCore import QPropertyAnimation, QEasingCurvefrom UIS import *# 主画面类 class MainWindow(QMainWindow, animationButton_ui.Ui_MainWindow):def __init__(self):super().__init__()self.setup…

【OpenCV C++20 学习笔记】图片处理基础

OpenCV C20 图片处理基础 VS 2022 C20 标准库导入的问题头文件包含以及命名空间声明main函数读取图片读取检查显式图片写入图片 完整代码bug VS 2022 C20 标准库导入的问题 VS还没有完全兼容C20。C20的import语句不一定能正确导入标准库,所以必须要新建一个头文件专…

基站光伏直流叠光能效管理方案

安科瑞 华楠 基站现状和趋势 5G基站是专门提供5G网络服务的公用移动通信基站。5G基站主要用于提供5G空口协议功能,支持与用户设备、核心网之间的通信。按照逻辑功能划分,5G基站可分为5G基带单元与5G射频单元,二者之间可通过CPRI或eCPRI接口…

Flink 技术与应用(一)

Flink技术与应用(初级篇) 起源 Apache Flink 是一个开源的大数据处理框架,其起源可以追溯到一个名为 Stratosphere 的研究项目,旨在建立下一代大数据分析引擎,2010 年,从 Stratosphere 项目中分化出了 Fl…

基于深度学习算法,支持再学习功能,不断提升系统精准度的智慧地产开源了。

智慧地产视觉监控平台是一款功能强大且简单易用的实时算法视频监控系统。它的愿景是最底层打通各大芯片厂商相互间的壁垒,省去繁琐重复的适配流程,实现芯片、算法、应用的全流程组合,从而大大减少企业级应用约95%的开发成本。通过计算机视觉和…

OpenCV图像滤波(2)均值平滑处理函数blur()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 在OpenCV中,blur()函数用于对图像应用简单的均值模糊(mean blur)。这种模糊效果可以通过将图像中的每个像素替…