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

链表操作(一)

一、链表的引入: 1、在引入链表之前,我们先来回忆之前为什么要引入单链表介绍:它是解决的数组的数组的大小比较死板不容易扩展的问题;使用堆内存来存储数据,将数据分散到各个节点之间,其各个节点在内存中可以不相连...局限性主要体现在单链表只能经由指针单向移动(一旦指针移动过某个节点就无法再回来,如果要再次操作这个节点除非从头指针开始再次遍历一次),因此单链表的某些操作就比较麻烦(算法比较有局限)。...这里可以看我之前写的单链表操作文章结合一下,就能非常好理解单链表的局限性了。...pPrev->data); return 0; } 代码演示结果: 三、小结: 以上代码链接:https://github.com/1121518wo/linux-/tree/master 对于链表内部元素插入操作...好了今天的分享就到这里了,后期还有链表的删除和遍历操作都会写到甚至Linux内核链表的内容也会分享给大家的。

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

    【数据结构】单链表链表

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

    12410

    java手写链表

    链表 链表中的每个节点即指向前面一个节点,也指向后面一个节点,就像丢手绢游戏一样,每个人都手拉手 。...node;//这里直接node.next=node2 node.prev=this.tail;//node2.prev = node this.tail=node;//为下次做铺垫 不得不说,这个java的链表比...data);         System.out.println("删除后结果");         doubleLinkedList.print();     } } 总结 这里我有个概念混淆了,链表链表是结点...1和2能相互指向的链表,和头插入和尾插入没关系,但是链表却是需要两个结点,一个从头遍历,一个从尾遍历嘛 废江博客 , 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权 转载请注明原文链接...:java手写链表

    54510

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

    链表 链表和单链表的区别就是,一个结点除了有指向后一个结点的指针域,还有一个指向前一个结点的指针域,所以建表的代码为: typedef struct DNode{ int data;...return ERROR;//内存分配失败 } L->next = NULL; L->prior = NULL;//头结点的前驱永远是NULL return OK; } 链表的查找操作和单链表相同...和单链表不同的操作在于插入和删除,不同点是链表的插入和删除需要同时修改两个方向的指针。...循环链表 循环单链表 表尾指向头结点 循环链表 在什么的链表的插入和删除操作中,如果p是最后一个结点,那么p->next就是NULL ,但是使用循环链表的话就不会出现那种情况。...typedef struct { int data; int next;//下一个元素的数组下标 }SLinkList[MaxSize]; 初始化:把a[0]的next设为-1即可 关于静态链表的其他操作这里不写了

    42540

    数据结构--链表

    插入和删除操作更灵活,但每个节点占用更多内存。 2.带头或不带头 带头节点: 链表有一个额外的头节点,它不存储实际数据,只作为链表的起始点。...本节我们所讲的链表即为双向带头循环链表。 三、链表的概念与基本结构 1.概念 链表简介 链表是一种链表变体,每个节点都包含三个部分: 存储的数据。...struct ListNode* next;//指针域,指向后一个节点 }LN; 三、链表的常见操作 1.创建节点 //申请节点 LN* ListBuyNode(DataType x) { LN...ListPrint(plist); ListDestory(plist); plist = NULL; } int main() { test01(); return 0; } 六、总结 带头节点的链表在进行节点的插入和删除操作时具有较好的灵活性...头节点的存在简化了链表操作的边界条件,减少了对空链表链表边界的特殊处理。通过本文的实现和示例代码,你应该能掌握链表的基本操作,并能够将其应用于实际的编程任务中。 希望这个博客对你有帮助!

    6210

    【数据结构】C语言实现链表的基本操作

    链表 导言 大家好,很高兴又和大家见面啦!!! 经过前面几个篇章的内容分享,相信大家对顺序表和单链表的基本操作都已经熟练掌握了。今天咱们将继续分享线性表的链式存储的第二种形式——链表。...在今天的内容中,咱们将介绍链表的创建以及一些基本操作,接下来跟我一起来看看吧! 一、单链表链表 线性表的链式存储称为链表链表是由数据域和指针域组成。...接下来我们就来看一下与链表相关的基本操作; 二、链表类型的创建 我们首先来看一下链表的类型创建的基本格式: //链表类型创建的基本格式 typedef struct DNode { ElemType...O(1); 如果是已知某一结点,需要查找位序在该结点前面或者后面的结点的话,那对应的时间复杂度就是O(n); 七、链表的插入 链表的插入操作也是有前插与后插操作,前插操作的逻辑与单链表一致,都是通过在指点结点的后面插入一个新的结点...,再对数据域中存储的数据进行移动从而完成前插操作,下面我们先来看一下链表前插操作的基本格式: //链表的前插操作 bool InsertPriorDNode(DNode* p, ElemType e

    43710

    C语言链表,循环链表,静态链表讲解(王道版)

    目录 一、链表 初始化(带头结点): 链表的插入: 链表的遍历  循环链表  循环单链表的初始化 循环链表的初始化 链表的插入 链表的删除 静态链表 定义静态链表 插入 删除 ---- 一...、链表 在单链表中,每个元素都附加了一个指针域,指向下一个元素的存储位置。...在双向链表中,每个元素都附加了两个指针域,分别指向前驱节点和后继节点。 单链表只能向后操作,不能向前操作。...为了向前、向后操作方便,可以给每个元素都附加两个指针域,一个存储前一个元素的地址,一个存储下一个元素的地址。这种链表被称为双向链表示。...时间复杂度O(n) 循环链表 在单链表中,只能向后操作,不能向前操作,如果从当前节点开始,则无法访问该节点前面的节点; 如果最后一个节点的指针指向头节点,形成一个环,就可以从任何一个节点出发,访问所有节点

    1.1K10

    对LinkedList ,单链表链表的理解

    二.链表 1.链表的概念及结构:链表是一种 物理存储结构上非连续 存储结构,数据元素的 逻辑顺序 是通过链表中的引用链接次序实现的就像一个火车。...,所有小于x的结点排在大于或等于x的结点之前: 注意:这里我的方法是,改完后,链表数据从小到大的,而做题在牛客网是,要求反过来(但是方法都一样) 理解视频:链表分割-CSDN直播 链表分割 //链表的分割...,找出它们的第一个公共结点: 方法:先找到哪个链表长,再让长的链表先走,他们的差值步,最后两个链表一起走,直到他们第一次相遇。...,ps指向短的链表 //3.操作两个链表pl和ps,长的链表(pl)先走链表的差值,然后再一起走直到相交 while (len !...2.实现: 这里注意一下删除链表指定位置Remove的节点 :可以优化一下代码,先删除头节点,之后尾节点和中间任意位置节点,有重复代码,(cur.prev.next = cur.next)可以共用

    8010

    【简单】数组模拟的链表

    实现一个链表链表初始为空,支持 \rm{5} 种操作: 在最左侧插入一个数; 在最右侧插入一个数; 将第 k 个插入的数删除; 在第 k 个插入的数左侧插入一个数; 在第 k 个插入的数右侧插入一个数...现在要对该链进行 M 次操作,进行完所有操作后,从左到右输出整个链表。...注意:题目中第 k 个插入的数并不是指当前链表的第 k 个数,是按插入时间的第 k 个数。 输入格式 第一行包含整数 M,表示操作次数。...接下来 M 行,每行包含一个操作命令,操作命令分为: "L x",表示在链表的最左端插入数 "R x",表示在链表的最右端插入数 "D k",表示将第 "IL k x",表示在第 x; "IR k...输入样例 10 R 7 D 1 L 3 IL 2 10 D 3 IL 2 7 L 8 R 9 IL 4 7 IR 2 2 输出样例 8 7 7 3 2 9 题解 (链表) 数据结构 单链表由于太过于基础

    86610

    【一个神奇的数据结构-异或链表】拥有单链表的空间,效率如链表

    思路和上面通过加法有点像链表看这个的应该都会,我直接上图我们把中间某一个节点单独提取出来,就会是这样其中prev是上一个节点的地址,next是下一个节点的地址属于两个指针域,那么我们能否用一个指针域来代替两个呢如果能够代替...addr(A) ⊕ addr(C)获取B的前驱A的地址addr(A) = B->xorPtr ⊕ addr(C)获取B的后继C的地址addr(C) = B->xorPtr ⊕ addr(A)通过以上的几种操作...,就可以遍历整个链表,在处理添加、插入、删除等操作时同普通的双向链表类似注意:这些异或和加法相关的操作都是针对指针值的本身,即指针转换为无符号整型数的结构,不能跟指针的运算操作混淆。...下面是代码:#include using namespace std;//通过异或运算实现链表typedef struct node{ int v; struct node

    58233

    线性表--单链表--循环链表--链表--三表总结(七)

    链表: ? 单链表就好比是一条路走到黑,无法回头,如果要访问任意结点,每次只能从头访问,也就是顺序访问,它的遍历只能是一个方向,不能后退 循环链表: ? ?...循环链表中没有NULL指针,涉及遍历时,终止条件不再是单链表的P!...=NULL;而是判断他们是否等于某一个特定的指针,单链表只能从已知结出发,访问其后续结点,而循环链表从已知结点出发,可以访问链表中所有结点。 双向链表: ?...虽然有了循环链表,但是如果数据庞大,想要得到已知结点前面的数据,再跑一圈的成本有点大,这个时候,双向链表就出来了,双向链表增加了前驱指针,它可以随心所欲,向前,或者是向后访问。...总结: 单链表:如果访问任意结点每次只能从头开始顺序向后访问。 单循环链表:可以从任何一个结点开始,顺序向后访问到达任意结点。 双向链表:可以从任何结点开始任意向前向后双向访问。

    1.1K30

    【C语言】探索数据结构:单链表链表

    链表的概念和结构 概念: 链表是一种物理存储结构上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。...也可能不连续 链表的分类 虽然说有8种链表结构,但是现实中主要使用的只有两种结构: 无头单向非循环链表:结构简单,一般不会单独用来存数据。...带头双向循环链表:结构最复杂,一般用在单独存储数据。实际中使用的链表数据结构,都 是带头双向循环链表。另外这个结构虽然结构复杂,但是使用代码实现以后会发现结构会带 来很多优势,实现反而简单了。...带头双向循环链表是双向链表的一种特殊形式,它有以下特点: 带头:链表中有一个头节点,它不存储实际数据,只用于标识链表的起始位置。...初始化主要是对链表的头--哨兵节点进行操作,它不保存具体的值(可以随便设置),它的存在可以确保链表一定不为空 //初始化 void InitList(ListNode** pHead) {

    11310

    链表的基本操作_简单链表

    链表的基本操作链表 链表的基本操作 一:单链表的基础操作 二:单链表的建立 头插法 尾插法 三:单链表的遍历 四:单链表结点数目判断 五:单链表的插入 链表头插入 任意结点插入 链表尾部插入...六:单链表的删除 七 :单链表的查询 一:单链表的基础操作 为什么需要链表?...---- 二:单链表的建立 单链表的建立即从无到有创建一个链表,一个一个的分配结点的储存空间,然后输出每一个结点的数据域,然后建立结点之间的关系。...单链表的建立可以分为两种方法,(1)头插法,(2)尾插法(更易理解) 头插法 即在单链表的头部插入新的结点的方法成为头插法。 数据读入顺序和链表的结点顺序正好相反。...链表的插入,有三种方式,可以从链表的头部插入,可以从链表的尾部插入,也可以在指定位置进行插入。

    60920
    领券