首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

数据结构】单链表、双链表

链表的概念和结构 概念: 链表是一种物理存储结构上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。...也可能不连续 链表的分类 虽然说有8种链表结构,但是现实中主要使用的只有两种结构: 无头单向非循环链表:结构简单,一般不会单独用来存数据。...带头双向循环链表:结构最复杂,一般用在单独存储数据。实际中使用的链表数据结构,都 是带头双向循环链表。另外这个结构虽然结构复杂,但是使用代码实现以后会发现结构会带 来很多优势,实现反而简单了。...无头单向非循环链表的实现 单链表的尾部插入 这里需要注意的是,插入时可能头节点为空,要改变指针,所以要传二级指针 //尾插 void SLPushBack(SLNode** pphead, SLDataType...void InitList(ListNode** pHead); // 双向链表销毁 void ListDestory(ListNode* pHead); // 双向链表打印 void ListPrint

10210
您找到你想要的搜索结果了吗?
是的
没有找到

数据结构——链表

由数据域和指针域两部分组成 - 数据域:存储元素数值数据 - 指针域:存储直接后继结点的存储位置 链表:n 个结点由指针链组成一个链表。...它是线性表的链式存储映像,称为线性表的链式存储结构 - 单链表 - 结点只有一个指针域的链表,称为单链表或线性链表 - 双链表 - 有两个指针域的链表,称为双链表 - 循环链表...- 首尾相接的链表称为循环链表 头指针 - 指向链表中第一个结点的指针 首元结点 - 指链表中存储第一个数据元素a1的结点 头结点 - 在链表的首元结点之前附设的一个结点;数据域内只放空表标志和表长等信息...链表的特点 结点在存储器中的位置是任意的,即逻辑上相邻的数据元素在物理上不一定相邻 访问时只能通过头指针进入链表,并通过每个结点的指针域向后扫描其余结点,所以寻找第一个结点和最后一个结点所花费的时间不等...,只能按链表的顺序进行访问(顺藤摸瓜) 顺序表和链表的比较 存储结构比较项目 顺序表 链表 存储空间 预先分配,会导致空间闲置或溢出现象 动态分配,不会出现存储空间闲置或溢出现象 存储密度 不用为表示结点间的逻辑关系而增加额外的存储开销

58185

数据结构——链表

由数据域和指针域两部分组成 数据域:存储元素数值数据 指针域:存储直接后继结点的存储位置 链表:n 个结点由指针链组成一个链表。...它是线性表的链式存储映像,称为线性表的链式存储结构 单链表 结点只有一个指针域的链表,称为单链表或线性链表链表 有两个指针域的链表,称为双链表 循环链表 首尾相接的链表称为循环链表 头指针 指向链表中第一个结点的指针...首元结点 指链表中存储第一个数据元素a1的结点 头结点 在链表的首元结点之前附设的一个结点;数据域内只放空表标志和表长等信息 设置头结点的好处 便于首元结点的处理 首元结点的地址保存在头结点的指针域中...,所以在链表的第一个位置上的操作和其它位置一致,无须进行特殊处理; 便于空表和非空表的统一处理 无论链表是否为空,头指针都是指向头结点的非空指针,因此空表和非空表的处理也就统一了。...链表的特点 结点在存储器中的位置是任意的,即逻辑上相邻的数据元素在物理上不一定相邻 访问时只能通过头指针进入链表,并通过每个结点的指针域向后扫描其余结点,所以寻找第一个结点和最后一个结点所花费的时间不等

44120

数据结构_链表

数据结构_LinkedList链表 前言: 此类笔记仅用于个人复习,内容主要在于记录和体现个人理解,详细还请结合bite课件、录播、板书和代码。...NULL) 节点/结点:在数据结构中,每一个数据节点/结点对应一个存储单元,节点/结点就是存储单元的地址(比如在链表里,结点就是链表结构体的地址) 注意: 从上图中可以看出,链式结构在逻辑上一定是连续的...更多情况下是作为其他数据结构的子结构,比如哈希桶、图的邻接表等。另外这种结构在面试题中出现的概率比较高。 带头双向循环链表:结构最复杂,一般用来单独存储数据用。...实际中使用的链表数据结构,都是带头双向循环链表。另外这个结构虽然结构复杂,但是使用代码实现以后会发现结构会带来很多优势,实现反而比较简单了,后面我们代码实现了就知道了。...单链表的实现 因为本人太懒了所以不想再写一遍了,此处放上我写的用C++实现的带头单向不循环链表 数据结构_SinglyLinkedList(C++.md 链表OJ 复制带随机指针的链表 复制一个新的链表

18510

数据结构链表

1.链表的定义: 链表(Linked List)是一种常见的基础数据结构,是一种线性表,但是并不会按线性的顺序存储数据,而是在每一个节点里存到下一个节点的指针(Pointer)。...在计算机科学中,链表作为一种基础的数据结构可以用来生成其它类型的数据结构。...而链表是一种自我指示数据类型,因为它包含指向另一个相同类型的数据的指针(链接)。 链表允许插入和移除表上任意位置上的节点,但是不允许随机存取。链表有很多种不同的类型:单向链表,双向链表以及循环链表。...链表通常可以衍生出循环链表,静态链表,双链表等。对于链表使用,需要注意头结点的使用。 2. 示例分析: 2.1例子1: leet-code:25....环形链表 给定一个链表,判断链表中是否有环。为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。

53720

数据结构链表

---- 数据结构链表:: SList.h #pragma once #include #include #include typedef...概念:链表是一种物理存储结构上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的....实际中链表的结构非常多样,以下情况组合起来就有8种链表结构. 1.单向或者双向  2.带头或者不带头  3.循环或者非循环 虽然有这么多的链表结构,但是我们实际中最常用还是两种结构. ...无头单向非循环链表: 结构简单,一般不会用来单独存数据,实际上更多是作为其他数据结构的子结构,如哈希桶,图的邻接表等....带头双向循环链表: 结构最复杂,一般用来单独存储数据,实际中使用到的链表数据结构,都是带头双向循环链表,这个结构虽然复杂,但是使用代码实现以后会发现结构会带来很多优势,实现反而简单了.

27720

数据结构链表(单链表

前言 数据结构之顺序表中我们有讲到顺序表有一些问题和缺点,为了能解决顺序表的问题,我们引入一个新的线性表——链表 一、链表 链表是一种物理存储结构上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表...: 1.无头单向非循环链表; 2.有头双向循环链表。...1.无头单向非循环链表:结构简单,一般不会单独用来存数据。实际中更多是作为其他数据结构的子结构,如哈希桶、图的邻接表等等。 2. 带头双向循环链表:结构最复杂,一般用在单独存储数据。...实际中使用的链表数据结构,都是带头双向循环链表。另外这个结构虽然结构复杂,但是使用代码实现以后会发现结构会带来很多优势,实现反而简单。 我们今天主要介绍的是无头单向非循环链表(单链表)。...本文作者也是一个正在学习编程的萌新,目前也只是刚开始接触数据结构这方面的内容,如果有什么内容方面的错误或者不严谨,欢迎大家在评论区指出。

24740

数据结构-链表

链表结构 链表结构五花八门,今天我重点给你介绍三种最常见的链表结构,它们分别是:单链表、双向链表和循环链表。我们首先来看最简单、最常用的单链表。...链表随机访问的性能没有数组好,需要 O(n) 的时间复杂度。 循环链表 循环链表是一种特殊的单链表。实际上,循环链表也很简单。它跟单链表唯一的区别就在尾结点。...我们知道,单链表的尾结点指针指向空地址,表示这就是最后的结点了。而循环链表的尾结点指针是指向链表的头结点。从我画的循环链表图中,你应该可以看出来,它像一个环一样首尾相连,所以叫作“循环”链表。...双向循环链表 了解了循环链表和双向链表,如果把这两种链表整合在一起就是一个新的版本:双向循环链表。...【可选 循环链表、双向链表】,支持增删操作 单链表反转链 表中环的检测 两个有序的链表合并 删除链表倒数第 n 个结点 求链表的中间结点 思考题:基于链表的 LRU 算法 LRU 思路一 如果此数据之前已经被缓存在链表中了

38210

数据结构-链表

链表结构 链表结构五花八门,今天我重点给你介绍三种最常见的链表结构,它们分别是:单链表、双向链表和循环链表。我们首先来看最简单、最常用的单链表。...链表随机访问的性能没有数组好,需要 O(n) 的时间复杂度。 循环链表 循环链表是一种特殊的单链表。实际上,循环链表也很简单。它跟单链表唯一的区别就在尾结点。...image.png 双向循环链表 了解了循环链表和双向链表,如果把这两种链表整合在一起就是一个新的版本:双向循环链表。...【可选 循环链表、双向链表】,支持增删操作 单链表反转链 表中环的检测 两个有序的链表合并 删除链表倒数第 n 个结点 求链表的中间结点 思考题:基于链表的 LRU 算法 LRU 思路一 如果此数据之前已经被缓存在链表中了...https://time.geekbang.org/column/article/41149 algo: 数据结构和算法必知必会的50个代码实现 https://gitee.com/TheAlgorithms

30310

数据结构 - 链表

链表的定义 链表(Linked list)是一种常见的基础数据结构,是一种 线性表的链式存储结构,存储地址空间不需要是连续的,而是在每一个节点(数据存储单元)里存放下一个节点的位置信息(即地址)。...链表: n个结点由 指针链 组成一个链表。它是线性表的链式存储映像,称为线性表的链式存储结构。...单向链表 单向链表也叫单链表,是链表中最简单的一种形式,它的每个节点包含两个域,一个数据域和一个链接域(地址域)。...地址域 next 用来存放下一个节点的位置,但最后一个结点的地址域要存储链表头结点的地址。 优点: 从链表中的任一个结点出发均可找到链表中其他结点。 双向链表 一种更复杂的链表是 双向链表。...优点: 方便找链表中的某个结点的前驱结点。 小扩展 头指针 头指针是指链表指向第一个结点的指针,若链表有头结点,则是指向头结点的指针。 头指针具有标识作用, 所以常用头指针冠以链表的名字。

45941

数据结构-链表

链表是一种常见的重要的数据结构,他的特点是动态地进行存储分配。 1.链表有哪些优势? 举个栗子:如果事先不知道不知道要存放的数据的长度,就要把数组定的足够大。...链表能够比较好的解决这两种情况。 2.什么是链表?...链表有一个“头指针”,它指向一个元素,这个元素在链表中被称为“结点”,而每一个“结点”应该包含两个部分:用户需要的数据和下一个结点的地址(指针)。...至此,链表结束。 3.链表中存放的地址是不连续的? 想要访问一个链表,必须知道链表的“头指针”。 4.如何建立一个链表? 用结构体变量建立链表最为合适。...b.next = &c; c.next = NULL; 将链表的“头指针”head赋值给指针p,其中head指向的结构体变量a的首地址,再用p输出这个链表中的实际数据。

19010

数据结构链表

总表:《数据结构?》 工程代码 Github: Data_Structures_C_Implemention -- Link List ---- 1、什么是链表?...内存结构:内存中的结构,如:struct、特殊内存块...等等之类; ---- 2、链表共分几类? 链表常用的有 3 类: 单链表、双向链表、循环链表。 ?...链表.png 链表的核心操作集有 3 种:插入、删除、查找【遍历】 单链表链表 [Linked List]:由各个内存结构通过一个 Next 指针链接在一起组成,每一个内存结构都存在后继内存结构【...对应的结束代码同样是 if (p == DoubleCircularList_Head(l)) { p = NULL; break; } ; ---- 参考书籍: 1、《算法精解_C语言描述(中文版)》 2、《数据结构与算法分析...下一篇,《数据结构:栈与队列》

92532

数据结构-链表

链表是一种物理存储单元上非连续、非顺序的存储结构,其物理结构不能只管的表示数据元素的逻辑顺序,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。...链表由一系列的结点(链表中的每一个元素称为结点)组成,结点可以在运行时动态生成。...1.单向链表 单向链表链表的一种,它由多个结点组成,每个结点都由一个数据域和一个指针域组成,数据域用来存储数据,指针域用来指向其后继结点。...循环链表链表整体要形成一个圆环状。...在单向链表中,最后一个节点的指针为null,不指向任何结点,因为没有下一个元素了。 实现循环链表,只需要让单向链表的最后一个节点的指针指向头结点即可。

24020

数据结构(4)双链表,循环链表,静态链表

链表链表和单链表的区别就是,一个结点除了有指向后一个结点的指针域,还有一个指向前一个结点的指针域,所以建表的代码为: typedef struct DNode{ int data;...和单链表不同的操作在于插入和删除,不同点是双链表的插入和删除需要同时修改两个方向的指针。...循环链表 循环单链表 表尾指向头结点 循环双链表 在什么的双链表的插入和删除操作中,如果p是最后一个结点,那么p->next就是NULL ,但是使用循环链表的话就不会出现那种情况。...静态链表 链表的每个结点在内存中的分布是随机的,静态链表就是建立一个固定的区间,结点在这固定的区间内随机存储。...计划从明天开始栈和队列,静态链表这里先大概了解原理,具体实现之后再补。‍️

39840

java链表数据结构是什么_java 链表数据结构

首先,单链表相对于队列的优势在于存储地址不是连续的,这样的意义在于,操作其中的某一个位置的元素时不需要对之前的其他元素都进行内存操作,大大的为我们的计算机减压了。...next;//下一个结点的引用 Object obj;//结点元素 publicNode(Object obj){this.obj=obj; } } 然后就是我们的LinkedList类,先要定义一个空链表...: Node head=null;//创建一个空链表,头结点 Node last=head;//尾结点 打印链表有两种方法,可以采用递归,也可以使用非递归的方法,如下: Java代码 /*** 非递归打印元素的方法...说了这么多,增删查改正式开始: 向链表中添加元素。...判断一个链表已经到达末尾的依据是该结点的next引用已经为Null,所以要向末尾添加一个结点,先要把新增结点放在最后,再把末尾结点向后移位,具体操作过程如下图: 代码如下: Java代码 /*** 向指定链表添加元素的方法

27820

数据结构链表

数据结构是一种分析、存储、组织数据的方法与逻辑,它考虑了数据之间的特性与相互关系,简单地说,数据结构就是对数据与算法的研究。...数据结构分为8类有:数组、栈、队列、链表、树、散列表、堆、图。 对我们个人而言,掌握数据结构是码农进入大厂的敲门砖,也是我们非计算机专业进入大厂的拦路虎。...掌握数据结构能够锻炼我们的抽象能力,分析能力,逻辑推理能力。工作时虽然可能用不到,但是面试大厂时考察数据结构是逃不掉的。...即使我们不进入互联网行业,学习数据结构也对我们大有脾益,锻炼我们的coding能力。 下面不废话了,直接上'链表'吧!...其缺点是设计数据结构时较为麻烦,在查找数据时,无法像静态数据(如数组)那样可以随时读取数据,必须按照顺序查找到该数据为止。

53640

数据结构链表

通过节点指针的方式相互连接(单链表,双向链表,单向循环链表,双向循环链表) 说到链表里面的节点(指针)那么说说其节点的种类, 我们单向列表里面的指针叫做后继指针,位于第一个链表的头部得节点叫做头节点最后一个的尾部为尾部节点...(其中,头结点用来记录链表的基地址。...有了它,我们就可以遍历得到,而尾结点特殊的地方是:指针不是指向下一个结点,而是指向一个空NUll)上面说的是单链表那么双向链表呢,双向链表每个内存块会有两个节点的,分别前继节点和后继节点,这时候我们就会想他有两个几点那岂不是占用很多的内存...(最近最少使用策略) 将数据存入固定大小的链表中,按续插入 尾部 为最现插入的,当进来新的数据的时候先进行表里查找查看是否有这个数据,如果有的话那就删除老的数据然后艰辛的数据插入到链表的头结点,如果没有在查看链表是否满了...,满了的话删除尾部节点,插入链表的头部。

25630
领券