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

【数据结构】线性表 ⑥ ( 双循环链表 | 双循环链表插入操作 | 双循环链表删除操作 | LinkedList 双循环链表源码分析 )

一、双循环链表插入操作处理 双循环链表 中 , 需要对 插入 / 删除 / 遍历 操作 进行特殊处理 , 因为需要调节 前驱指针 和 后继指针 两个指针 ; 如 : 双循环链表 中 , 如果要插入元素...指向 c ③ 将 c 后继指针 指向 b ④ 将 b 前驱指针 指向 c 二、双循环链表删除操作处理 ---- 下面的链表插入成功 , 顺序为 a , c , b , 如果要删除双循环链表...c 元素 , 只需要将 a 元素 后继指针 指向 b , 将 b 元素 前驱指针 指向 a 即可 ; c 元素没有指针指向后 , 会自动被内存回收 ; 三、LinkedList 双循环链表源码分析...LinkedList 链表是一个 双循环链表 , 下面的 Node 类 , 就是双循环链表 节点 ; private static class Node { E item...函数就是获取 双循环链表 元素方法 ; /** * 返回列表中指定位置元素。

24520

【数据结构】线性表 ⑤ ( 双循环链表 | 双循环链表特点 | 双循环链表插入操作处理 | 代码示例 - 使用 Java 实现 双循环链表 )

一、双循环链表 " 双循环链表 " 是 在 单循环链表 基础上 , 在每个 节点 中 , 新增一个 指针 , 指向 该节点 前驱节点 ; 双向循环链表 每个 节点 都包含 数据 和 两个指针 ,...: 双循环链表 中 , 可以在 任意位置 增删节点 , 双循环链表中可以双向遍历 , 增删节点 效率更高 ; LRU 缓存算法中 , 一般使用 双循环链表 数据结构 ; 三、双循环链表插入操作处理 双循环链表...b 节点 之间 , 当前状态是 a 后继指针 指向 b , b 前驱指针指向 a ; 如果要实现插入 c 元素 , 则需要 将 a 后继指针 指向 c , 将 c 前驱指针 指向 a ,...将 c 后继指针 指向 b , 将 b 前驱指针 指向 c ; 插入节点操作 需要执行四个步骤 : ① 将 c 前驱指针 指向 a ② 将 a 后继指针 指向 c ③ 将 c 后继指针...指向 b ④ 将 b 前驱指针 指向 c 四、代码示例 - 使用 Java 实现 双循环链表 Node类来表示双向循环链表节点 , 每个节点包含如下要素 : 数据项 data ; 指向 前一个节点

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

    C语言链表详解_c语言链表使用

    链表是一种常见基础数据结构,结构体指针在这里得到了充分利用。...链表可以动态进行存储分配,也就是说,链表是一个功能极为强大数组,他可以在节点中定义多种数据类型,还可以根据需要随意增添,删除,插入节点。链表都有一个头指针,一般以head来表示,存放是一个地址。...链表节点分为两类,头结点和一般节点,头结点是没有数据域链表中每个节点都分为两部分,一个数据域,一个是指针域。...作为有强大功能链表,对他操作当然有许多,比如:链表创建,修改,删除,插入,输出,排序,反序,清空链表元素,求链表长度等等。...下面是一个传入链表和要修改节点,来修改值函数。

    4.2K10

    C语言链表实例--玩转链表

    下图为最一简单链表示意图: 第 0 个结点称为头结点,它存放有第一个结点首地址,它没有数据,只是一个指针变量。...这样一种连接方式,在数据结构中称为“链表”。 而使用动态分配时,每个结点之间可以是不连续(结点内是连续)。...链表基本操作对链表主要操作有以下几种: 1. 建立链表; 2. 结构查找与输出; 3. 插入一个结点; 4. 删除一个结点; 建立一个三个结点链表,存放学生数据。...可编写一个建立链表函数 creat。...下方为创客专门针对C语言链表分析视频资料,对链表感兴趣可以看看学习下 1 C语言玩转链表 http://www.makeru.com.cn/live/1392_338.html?

    2K31

    C语言-链表(单向链表、双向链表)

    链表结构介绍 在前面章节已经学习了数组使用,数组空间是连续空间,数组大小恒定,在很多动态数据存储应用场景下,使用不方便;而这篇文章介绍链表结构,支持动态增加节点,释放节点,比较适合存储动态数据应用场景...链表节点是不连续,需要通过每个节点指针,来找到上一个节点或者下一个节点地址。...链表每个节点就是一个结构体变量,节点里有一个或者两个指针,可以保存上一个节点和下一个节点地址,方便遍历链表,删除、插入节点时定位位置。 2....实现功能如下: 初始化链表头 插入节点函数(链表任意位置插入,链表尾插入) 删除节点函数(链表任意位置删除、链表尾删除) 遍历链表,输出链表所有信息 #include #include...案例: 创建双向链表循环,实现插入、删除、遍历 双向链表在每个节点里新增加了一个指针,用于保存上一个节点地址,现在节点里一个用两个指针,一个保存上一个节点地址,一个保存下一个节点地址。

    2.1K30

    C语言链表实例--玩转链表

    下图为最一简单链表示意图:   第 0 个结点称为头结点,它存放有第一个结点首地址,它没有数据,只是一个指针变量。...链表每一个结点都是同一种结构类型。   指针域: 即在结点结构中定义一个成员项用来存放下一结点首地址,这个用于存放地址成员,常把它称为指针域。   ...这样一种连接方式,在数据结构中称为“链表”。   而使用动态分配时,每个结点之间可以是不连续(结点内是连续)。...链表基本操作对链表主要操作有以下几种:   1. 建立链表;   2. 结构查找与输出;   3. 插入一个结点;   4. 删除一个结点;   建立一个三个结点链表,存放学生数据。...可编写一个建立链表函数 creat。

    1.6K20

    C语言 | 链表概述

    “要成为绝世高手,并非一朝一夕,除非是天生武学奇才,但是这种人…万中无一” ——包租婆 这道理放在C语言学习上也一并受用。...在编程方面有着天赋异禀的人毕竟是少数,我们大多数人想要从C语言小白进阶到高手,需要经历是日积月累学习。 那么如何学习呢?当然是每天都练习一道C语言题目!! ? 作者 闫小林 白天搬砖,晚上做梦。...C语言链表概述 链表是一种常见重要数据结构。它是动态地进行存储分配一种结构,是根据需要开辟内存单元。 链表有一个“头指针”变量,它存放一个地址,该地址指向一个元素。...链表中每一个元素称为“结点”,每个结点都应包括两个部分 用户需要实际数据。 下一个结点地址。 链表中各元素在内存中地址可以是不连续。...C语言使用链表输出学号和成绩 #include//头文件 struct student //定义学生结构体 { int num; //学号 float score;//成绩

    1.2K30

    C语言链表实现

    我尝试用最简单语言与代码来描述链表,事实上它本身也很简单 静态单链表实现 下面一部分讨论都将围绕上面这幅图片展开,既然是逐步实现,我不考虑在开头就让这个单链表完美实现,它将只有两个部分:链表创建...这个疑问你可以自己解答比较好 动态单链表实现 到这里一个简单链表就已经实现了,但是我们还需要继续改进,因为我们有时候不知道每个节点储存数据,所以我们就需要一个动态链表了,下面这个将实现把用户输入数据以链式结构储存...再想想上面图片,下面要介绍就是双向链表,双向链表与单项链表区别就在于它有一个指向前一个节点指针,于是我们就应该定义这样结构体 typedef struct NODE { int data...; node *tail=c; a->data=9; a->next=b; a->pre=NULL; b->data=17; b->next=c; b->pre=a; c->data...=6; c->next=NULL; c->pre=b; //输出 /*node *print_head=head; while(print_head!

    5.4K30

    C语言 list 链表

    大家好,又见面了,我是你们朋友全栈君。...back 2.2. pop_front 2.2. pop_back 2.2. size 2.2. empty 2.2. clear 三、源码 仓库地址 example 一、list简介 这里用双向链表实现...注意:考虑性能,这边所有操作均不是线程安全,如多线程使用请合理构建或自行加锁。...包含方法 2.1. push_front 功能 插入数据到 list 头部 参数 list:list指针,data:插入数据指针,len:插入数据 返回值 int 0:成功, -1 : 超过链表最大长度或者数据长度过长...内存申请失败 2.2. push_back 功能 插入数据到 list 尾部 参数 list:list指针,data:插入数据指针,len:插入数据 返回值 int 0:成功, -1 : 超过链表最大长度或者数据长度过长

    1.3K30

    C语言 | 链表概述

    C语言链表概述 链表是一种常见重要数据结构。它是动态地进行存储分配一种结构,是根据需要开辟内存单元。 链表有一个“头指针”变量,它存放一个地址,该地址指向一个元素。...链表中每一个元素称为“结点”,每个结点都应包括两个部分 用户需要实际数据。 下一个结点地址。 链表中各元素在内存中地址可以是不连续。...C语言使用链表输出学号和成绩 #include//头文件 struct student //定义学生结构体 {   int num; //学号   float score;//成绩   ...以上,如果你看了觉得对你有所帮助,就给小林点个赞,分享给身边的人叭,这样小林也有更新下去动力,跪谢各位父老乡亲啦~ C语言学习路线    C语言开发工具 VC6.0、Devc++、VS2019使用教程...100道C语言源码案例请去公众号:C语言入门到精通

    1.4K30

    9.4 C语言链表

    01链表 1、链表是一种常见重要数据结构。它是动态地进行存储分配一种结构,是根据需要开辟内存单元。 2、链表有一个“头指针”变量,它存放一个地址,该地址指向一个元素。...3、链表中每一个元素称为“结点”,每个结点都应包括两个部分 (1)用户需要实际数据。 (2)下一个结点地址。 4、链表中各元素在内存中地址可以是不连续。...5、要找某一元素,必须先找到上一个元素,根据它提供下一元素地址才能找到下一个元素。如果不提供“头指针”,则整个链表都无法访问。 6、链表如同一条铁链一样,一环扣一环,中间是不能断开。...7、链表这种数据结构,必须利用指针变量才能实现,即一个结点中应包含一个指针变量,用它存放下一结点地址。 C语言 | 将一个二维数组行列元素互换 更多案例可以go公众号:C语言入门到精通

    1.3K2725

    C语言 | 简单链表

    “要成为绝世高手,并非一朝一夕,除非是天生武学奇才,但是这种人…万中无一” ——包租婆 这道理放在C语言学习上也一并受用。...在编程方面有着天赋异禀的人毕竟是少数,我们大多数人想要从C语言小白进阶到高手,需要经历是日积月累学习。 那么如何学习呢?当然是每天都练习一道C语言题目!! ? 作者 闫小林 白天搬砖,晚上做梦。...例42:C语言实现一个简单链表,它由3个学生数据结点组成,要求输出各结点中数据。 解题思路:读者在学习这道例题时候,应该首先分析三个问题。 各个结点是怎么样构成链表?...=10107;//学号赋值 c.score=85.0;//成绩赋值 head=&a;//将第1个结点起始地址赋给头指针head a.next=&b;//将第2个结点起始地址赋给第1个结点...next成员 b.next=&c;//将第3个结点起始地址赋给第2个结点next成员 c.next=NULL;//第3个结点next成员赋给null point=head; do

    1.9K2119

    C语言创建链表

    一、链表中结点存储        链表结点左边一部分是存放数据,右边一部分是后继指针指向下一个结点地址。...C语言中通常定义一个结构体类型来存储一个结点,如下: struct node { int data; struce node *next; //下一个结点类型也是struct node...,所以后继指针类型也必须是struct node * }; 二、让我们把结点连起来吧        想要把结点一个个串起来,还需要三个struct node *类型指针:head(头指针,指向链表开始...,方便从头遍历整个链表)、p(临时指针,指向那些还未连接结点)、q(当前指针,指向当前最新串入结点)。   ...域中 p->next=NULL; //设置当前结点后继指针指向空,也就是当前结点下一个结点为空   把新加入结点串进链表

    1.7K20

    C语言链表使用及链表实现原理

    链表是什么? 1.逻辑结构上⼀个挨⼀个数据,在实际存储时,并没有像顺序表那样也相互紧挨着。恰恰相 反,数据随机分布在内存中各个位置,这种存储结构称为线性表链式存储。...2.由于分散存储,为了能够体现出数据元素之间逻辑关系,每个数据元素在存储同时,要 配备⼀个指针,⽤于指向它直接后继元素,即每⼀个数据元素都指向下⼀个数据元素 ** 本身信息,称为“数据域”...下面是一个单链表实现过程 #include #include #include //结构体是⼀种⼯具,⽤这个⼯具可以定义⾃⼰数据类型 typedef struct...Student Stu; struct tagNode *pNext; } Node; //定义链表第...⼀个学⽣,即学⽣单链表头结点 Node *head = NULL; void printfNode() //遍历元素

    99410

    c语言 | 单链表实现

    今天分享是单链表。准确说,单链表不算是C语言内容,而是属于数据结构内容,因为它没有新知识点,只是利用了结构体和指针等知识。...但是它在C语言中应用还是很广泛,在RTOS中,也是非常多地方使用到了链表。今天暂时说一下单链表实现和简单应用,下一节当中再介绍双链表。 首先,要对单链表有个概念。...链表是由一个个节点构成,每个节点之间用指针方式连接起来,有一个头指针用来找到链表第一个节点,然后根据指针就可以找到每一个节点。...说明:在本次实验中,使用是vscode编辑器,编译环境是gcc,不建议使用VC6.0,因为VC6.0使用c语言标准太老了,很多语法都不支持,并且,VC6.0使用体验极差,没有代码高亮功能等等。...所以,推荐使用vscode编辑器,也可以使用windows自带编译器,打开cmd终端,使用gcc命令编译.c文件,生成.exe可执行文件后执行即可。

    2.1K30

    C语言链表排序_C语言版数据结构链表

    //以上搬运至郝斌老师数据结构中视频知识,然后依样画葫芦去写; //当然指针知识和链表基础知识要先懂: //首先先创建链表,如下: #include #...node * pNext; //创建指针域 }NODE, *PNODE; //相当于struct node,struct *node PNODE create_list() //创建链表...; //使新节点再次成为尾节点,和首次步骤一样 } return pHead; } //其次,对链表遍历是必须; void traverse_list(PNODE pHead...= NULL) { printf(“%d\t”, p->data); //相当于数组中p++ p = p->pNext; } } //这里需要对链表长度进行统计,才能对冒泡排序进行运算...= p) { p = p->pNext; count++; } return count; } //最后开始着手写链表排序,采用是冒泡排序: void sort_list

    1.8K30

    c语言链表详解

    前言:     上一期一起学习了数据结构初阶顺序表,发现顺序表有一些致命缺点,比如部分操作时间复杂度高,还是会存在空间浪费现象,今天为大家介绍链表就可以完美地解决这个问题。...文件分类:     还是和顺序表一样创建3个文件: Seqlist.h: 头文件,放入结构体和函数声明。 Seqlist.c:函数接口文件,用来存放函数定义。...test.c: 测试文件,在写代码过程中用来测试函数可行性。...打印链表函数:     链表打印和顺序表差不多,不再过多赘述,这里我加上->来区分: void SLprintf(SLNode* phead)//打印链表 { assert(phead); SLNode...查找函数:     在链表中查找数据,然后返回这个数据结构体地址,这个函数可以辅助后面指定数据进行操作函数实现,遍历这个链表即可: SLNode* SLfind(SLNode* phead, SListDatetype

    11110
    领券