首页 > 其他分享 >链表

链表

时间:2023-12-18 13:25:02浏览次数:28  
标签:存储 带头 链表 循环 双向 数据

1. 链表概念

使用数组存储数据的缺陷:

插入和删除需要移动数据 复杂度为O(N) 不好

那么,是否有一种存储结构 可以在插入删除数据时不需要移动数据 ?

答案是链表

什么是链表 ?

链表是一种在逻辑上连续存储 但是在物理上(内存空间)中不一定连续的存储结构, 如下图

链表中的每一个元素都是一个节点对象

每个节点对象由两部分组成:

1. val 数值域,存储数据

2. next 指针域,存储下一个节点的地址

链表的分类

链表以单向/双向,带/不带头,循环/非循环分为8类

在这8种中,重点掌握单向不带头非循环链表双向不带头非循环链表

因为笔试面试都是考单向不带头非循环(单链表),而双向不带头非循环链表是LinkList底层实现(双向链表)

什么是带头/不带头 ?

什么是循环和非循环 ?

单向/双向会在后序介绍双向链表时说明

2. 单链表结构及实现

单链表结构:

 

单链表的实现:

https://github.com/znxcmakhsd/DS/tree/main/12-14/MySingleList

一些重要操作的思路:

头插:

尾插:

index位置插入:

删除操作:

3. 双向链表结构及实现

结构:

实现:

https://github.com/znxcmakhsd/DS/tree/main/12-18/MyLinkedList

一些重要操作的实现思路:

4. ArrayList和LinkedList的区别

1. 从插入 删除 查找 修改来说

如果数据需要频繁的插入或者是删除,使用LinkedList

因为LinkedList底层是用双向链表存储数据插入删除数据只需要修改指向 不用移动数据,所以效率很高

 

如果数据需要被快速查找,使用ArrayList

因为ArrayList底层用数组存储数据,给定下标就能找到数据

 

2. 从底层实现来说

ArrayList底层用数组实现,以1.5倍扩容,可以会浪费空间

LinkedList底层用双向链表实现,数据节点随用随建,不需要扩容不会浪费空间

标签:存储,带头,链表,循环,双向,数据
From: https://www.cnblogs.com/xumu7/p/17899830.html

相关文章

  • 链表递归题型
    递归的定义在定义一个过程或函数时出现调用本过程或本函数的成分,称之为递归。若调用自身,称之为直接递归。若过程或函数p调用过程或函数q,而q又调用p,称之为间接递归。递归算法的设计递归的求解过程均有这样的特征:先将整个问题划分为若干个子问题,通过分别求解子问题,最后获......
  • 链表面试题解析
    链表面试题解析1.删除链表中=val的所有节点/***Definitionforsingly-linkedlist.*publicclassListNode{*intval;*ListNodenext;*ListNode(){}*ListNode(intval){this.val=val;}*ListNode(intval,ListNodenext){......
  • [LeetCode138-链表-中等] 复制带有随机指针的链表
    这道题是这样的,就是说有一个链表LindedNode,通常我们链表包含2个属性,一个是它的值val,另一个是它指向的下一个结点nextNode,但是这个题目中的链表还有一个属性,就是它还有个随机指针,这个随机指针可能指向链表中的任意结点(包括链表的结尾null结点,或者是自己)也就是说这个链表Lin......
  • 141.环形链表
    给你一个链表的头节点head,判断链表中是否有环。如果链表中有某个节点,可以通过连续跟踪next指针再次到达,则链表中存在环。如果链表中存在环,则返回true。否则,返回false。示例输入:head=[3,2,0,-4];输出:true思路:循环遍历链表,检查是否存在重复的节点,可以使用......
  • 代码随想录算法训练营第四天 | 24. 两两交换链表中的节点,19.删除链表的倒数第N个节点,
    一、24.两两交换链表中的节点题目链接:LeetCode24.两两交换链表中的节点学习前:思路:未新增虚拟结点。节点数为0,1,2需要另外讨论。当节点数>=2时,返回的head值为第2个节点,需要3个指针first、second、prev,分别是第一个节点和第二个节点,以及第一个节点的前节点。while(first......
  • 142. 环形链表 II
    1.题目介绍给定一个链表的头节点 \(head\) ,返回链表开始入环的第一个节点。 如果链表无环,则返回 \(null\)。如果链表中有某个节点,可以通过连续跟踪\(next\)指针再次到达,则链表中存在环。为了表示给定链表中的环,评测系统内部使用整数\(pos\)来表示链表尾连接到链表中的......
  • 142.环形链表II
    题目142.环形链表II要求给定一个链表的头节点 head ,返回链表开始入环的第一个节点。 如果链表无环,则返回 null。如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。为了表示给定链表中的环,评测系统内部使用整数 pos 来表示链表尾连接到链表中......
  • 算法学习Day4两两交换,链表相交,环形链表
    Day4两两交换,链表相交,环形链表ByHQWQF2023/12/16笔记24.两两交换链表中的节点给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。解法:迭代法迭代法使用了虚拟头节点的技巧,迭代法代码class......
  • 面试题 02.07. 链表相交
    题目面试题02.07.链表相交要求给你两个单链表的头节点headA和headB,请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点,返回null。思路和答案这道题目先用暴力破解,直接使用双层for循环,如下:/***暴力破解,双层for循环**@paramheadA*@param......
  • 19.删除链表的倒数第N个节点
    题目19.删除链表的倒数第N个节点要求给你一个链表,删除链表的倒数第n个结点,并且返回链表的头结点。答案先看看直接思路,首先遍历一遍,计算出元素的个数,之后计算出正向遍历要删除的元素,注意的是要创建一个虚拟节点,目的是可能删除头节点,如果删除头节点,没有虚拟节点,不易删除,当然......