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

单向循环链表-链表(单链表)的基本操作及C语言实现

图3 含有n个结点的链表   图 3 中,由于每个结点中只包含一个指针域,生成的链表又被称为线性链表或单链表。   ...图 4 头结点、头指针和首元结点   单链表中可以没有头结点,但是不能没有头指针!   链表的创建和遍历万事开头难,初始化链表首先要做的就是创建链表的头结点或者首元结点。...p; }   向链表中插入结点   链表中插入头结点,根据插入位置的不同,分为3种:   插入到链表的首部,也就是头结点和首元结点中间;插入到链表中间的某个位置;插入到链表最末端;   图 5 链表中插入结点...->next; temp->next=c; return p; }   注意:首先要保证插入位置的可行性,例如图 5 中单向循环链表,原本只有 5 个结点,插入位置可选择的范围为:1-6,如果超过6,...本身不具备任何意义单向循环链表,程序提示插入位置无效。

97830

数据结构(05)_链表01(单链表、静态单链表、单向循环链表)

链式存储结构的逻辑结构:   1.2.单链表   单链表中的节点定义: 注意:这里的struct是用来定义一个类,与class的访问属性相反,默认为public单链表的内部结构:头节点在单链表中的意义是...1.3.单链表的插入与删除:   插入:    node->value = e; node->next = current->next; Current->next = node...;   删除:    toDel = current->next; current->next = toDel->nex; delete toDel;   2.单链表的实现...解决方案:头节点构造时单向循环链表,避免调用泛指类型的构造函数,也即是说要自定义头节点的类型,并且该类型是一个匿名类型    mutable struct : public Object...22.3 单链表的最终实现    template class LinkList : public List { protected: int m_length

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

    【数据结构】线性表 ② ( 链式存储结构 - 链表 | 链表分类 - 单链表 双链表 非循环链表 循环链表 | 链表优缺点 )

    Object data; // 指向下一个节点 Node next; // 指向上一个节点 Node last; } 二、链表分类 - 单链表 / 双链表 / 非循环链表 / 循环链表 单链表...与 双链表 : 单链表 : 上述链表是 单链表 , 单链表 只有一个指针 指向下一个节点 ; 双链表 : 还有一种链表是 双链表 , 双链表 有两个指针 , 一个指向下一个节点 , 一个指向上一个节点...; 循环链表 : 如果 最后一个节点的指针 指向 第一个节点 , 那么这个链表就是循环链表 ; 链表可以分为以下四类 : 单链表 单循环链表 双链表 双循环链表 三、链表优缺点 链表 LinkedList...链表 LinkedList 缺点: 查询 性能低 : 如果要访问 链表中 指定位置的元素 , 需要从头节点开始遍历到目标位置 , 时间复杂度为O(n)。...消耗空间多 : 链表需要 额外的指针 来维护节点之间的关系,增加了存储空间的消耗。 线性表 选择 : 选择使用 顺序表 还是 链表,取决于具体的 应用场景 和 操作需求。

    41440

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

    单链表: ? 单链表就好比是一条路走到黑,无法回头,如果要访问任意结点,每次只能从头访问,也就是顺序访问,它的遍历只能是一个方向,不能后退 循环链表: ? ?...循环链表中没有NULL指针,涉及遍历时,终止条件不再是单链表的P!...=NULL;而是判断他们是否等于某一个特定的指针,单链表只能从已知结出发,访问其后续结点,而循环链表从已知结点出发,可以访问链表中所有结点。 双向链表: ?...总结: 单链表:如果访问任意结点每次只能从头开始顺序向后访问。 单循环链表:可以从任何一个结点开始,顺序向后访问到达任意结点。 双向链表:可以从任何结点开始任意向前向后双向访问。...在多数情况下的选择是使用双向循环链表,这样就完美了。 ? 若有错误,欢迎指正批评,欢迎讨论。 一生之中一定会遇到某个人,他打破你的原则,改变你的习惯,成为你的例外。

    1.1K30

    循环链表的实现_建立双向循环链表

    循环链表   循环链表是一个收尾相接的链表,将单链表的最后一个指针域改由NULL改为指向表头结点这就是单链式的循环链表,并称为循环单链表   带头结点的循环单链表的各种操作的算法实现与带头结点单链表的算法实现类似...单链表中的判别条件为p!=NULL或p->next!=NULL,而单循环链表判别条件是p!=L或p->next!=L   在循环单链表中附设尾指针有时候比附设头指针更简单。...如:在用头指针的循环单链表中找a1的时间复杂度是O(1),找an需要从头找到尾,时间复杂度是O(n),如果用为指针rear,找开始结点和终端结点的存储位置分别是rear->next->next和rear...域指向头结点 } } }   循环单链表的插入 #include #include #define len sizeof(Node) typedef...    方法一:先找到两个链表LA,LB的表尾,分别用p,q指向它,然后将第一个链表的表尾与第二个链表的第一个结点连起来,修改第二个表的尾q,使它的链域指向第一个表头 //头指针合并循环链表 #include

    75320

    单链表(无头单项非循环)

    前言 链表是一种物理存储结构上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的 。链表的形式有很多,本篇文章主要介绍的是单链表且无头结点。...链表的实现 初始化 在无头单项非循环链表中,需要声明一个数据域和指针域,指针域指向的是下一个节点的地址,数据域是当前节点的数据。...遍历单链表,就是从单链表的第一个节点一直访问到单链表的最后一个节点。...头插 头插法即前插法,逐个将新节点插入到链表的头部来创建,每次申请一个新节点,读入相应的数据元素值。传递的也是二级指针,将新节点的头节点给newnode->next,将newhead变成头节点。...单链表的查找实际上就是遍历单链表,遍历过程中,找到你所需要的数值,如果是的,就返回当前节点,不是就继续往下遍历,直到链表为空。

    10410

    单循环链表-带头双向循环链表的实现

    带头双向循环链表   前言   对于链表来说,不只有单链表这一个品种;   链表有很多种形态   按方向分:单向、双向   按带不带头:带头、不带头   按循环:循环、不循环   1、单向或则双向:...今天我们就来学习一下结构最复杂的带头双向循环链表!!!...;   虽然名字听上去比较复杂单循环链表,但是实现起来比单链表(全名:不带头、不循环、单向链表)更加简单,也不需要过多考虑特殊情况;   两种链表的比较:(上面是单链表,下面是带头双向循环链表)   结构分析...  首先链表的头节点是不存储有效数据的(该节点被称为哨兵位),其次我们只需要知道改头节点的指针就能找到整个链表单循环链表,并且便于对整个链表进行维护;   当然既然是双向的嘛,那节点一定有个指针域指向前一个节点...  该链表的尾插,比单链表的尾插简单太多了,不用遍历找尾:    // 双向链表尾插 void ListPushBack(ListNode* pHead, LTDataType

    61130

    单循环链表-这么好的单链表结构怎么能不会呢?带哨兵位头节点双向循环链表

    带头循环双向链表   优势是什么   先看看长啥样子   每一个节点都记录该节点的前后的节点,这会有什么好处呢?   ...带哨兵位头节点双向循环链表的基本操作   这一次,会写的规范一点。   准备3个文件,一个头件,一个链表操作文件,一个主函数所在的文件,和通讯录那一篇设计是一样的。   ...,释放所有节点   循环中,先把除头节点外的所有节点删除,出了循环再删除头节点。   ...return p; p = p->_next; } return NULL; }   在pos前插入   双向单链表的优势来了...不能删除头节点单循环链表,不然主函数中的头指针会非法访问。

    32610

    循环双向链表的

    链表的使用 初级版:   结构体   struct data{     struct data* next;     int data;   };   head=p1->p2->p3->p4->NULL...  需要删除节点p3时就很麻烦,我们需要从头去遍历,找到next指针为p3时将next指针指向p3的next;   为此方便起见,我们可以使用双向链表进行实现。...内核中是这样处理的,   创建一个双向循环链表   =>headp1p2p3p4=   向链表中指定位置插入节点   原有链prenext   这也是最基本的插入节点的方法...}   根据插入节点的方式写删除节点就容易的多了   _del(struct data * pre,struct data * next){     pre->next = next;     next...}   没有做释放的代码,创建链的时候需要用malloc去创建,内核中的双向链表正是这么实现的,   特别容易书写,不太会产生副作用。二级指向是在太难理解了

    29010

    循环链表及线性表的应用

    循环链表的应用之约瑟夫环问题以及线性表总结之顺序表与链表的比较   1.1问题说明   问题描述:编号为1,2,···,n的n个人围坐在一圆桌旁,每人持有一个正整数的密码。...基本要求:用不带表头结点的循环单链表表示围成圆圈的n个人;要求建立此循环单链表;某人离席相当于删除一个结点,要正确设置程序中循环终止的条件和删除结点时指针的修改变化。   ...struct LNode{   ElemType data;   ElemType sequence;   LNode *next;   }LNode,*LinkList;   //创建一个不带头节点的循环单向链表...这两种链表又可按链接形式的不同,区分为单链表,双链表和循环链表。   在实际应用中,对线性表采用哪种存储结构,要视实际问题的要求而定,主要考虑求解算法的时间复杂度和空间复杂度。...最后分享些循环链表及线性表的应用方面的资料   循环链表及线性表的应用 http://www.makeru.com.cn/course/details/1902?s=45051

    55530

    单链表的算法

    这样的数据单元叫做结点。 当多个结点通过指针指向,关联起来,就形成了一个链,即链表。 单链表 链表可分为单链表、双链表、循环链表。 本文先介绍单链表。 单链表就是沿着单方向的链表。...; } LNode, *LinkList; 基本算法 插入结点 假设要在单链表的a结点和b结点之间插入一个值为x的新结点。...] [1] destroyList, 销毁单链表 [2] initList, 初始化一个带头结点的空单链表,如果传入一个不为空的单链表,将被重置 [3] insertElem, 在单链表中第 i 个位置插入元素..., 判断单链表是否为空 [7] getElem, 获取单链表上位置为 pos 的元素 [8] locateElem, 获取元素 elem 在单链表上第一次出现的位置,如果不存在返回 -1 [9] getLength...const ElemType elems[], const int n) {     int i = 0;     STATUS_EN statu = OK;       // 按序将数组元素插入到单链表尾部

    67490

    单链表的实现

    之前学习了顺序表,接下来把链表的功能给模拟实现一遍 链表 链表是一种物理存储结构上非连续存储结构,数据元素的逻辑顺序是通过链表中的引用链接次序实现的 。...链表的结构有很多种,但是我们重点掌握两种: 无头单向非循环链表:结构简单,一般不会单独用来存数据。实际中更多是作为其他数据结构的子结构,如哈希桶、图的邻接表等等。...整体结构就长这个样子 无头双向链表:在Java的集合框架库中LinkedList底层实现就是无头双向循环链表。...链表的实现 第一个节点也称为头结点 head 依靠head 节点就可以找到所有的节点 单链表的模拟实现 creatList为我们已经创建好了一个链表,在它的基础上我们可以进行操作 实现接口的功能...public void clear() { head = null; } 直接让head 为空就行 ok以上就是整个单链表的模拟过程,这里只是简单入个门而已 单链表一般在笔试面试题常常出现

    8110

    单链表的应用

    上篇博客中,我们学习了单链表,为了更加熟练掌握这一知识点,就让我们将单链表的应用操练起来吧! 203. 移除链表元素 - 力扣(LeetCode) 思路一:遍历原链表,将值为val的节点释放掉。...while(pcur) { //找值不为val的值,插入到新链表中 if(pcur->val!...else {//不需要销毁节点 prev=pcur; pcur=pcur->next; count++; } } //当链表中只有一个节点的情况跳出循环...若pcur的节点小于x,让它头插在新链表中。 若pcur的节点值大于或等于x,尾插。 思路三:创建新链表,小链表和大链表。 将小链表的尾结点和大链表的第一个有效节点首位相连。...尾结点的next指针是否为空。 单链表:不带头单向不循环 双向链表:带头双向循环

    11010

    【链表问题】删除单链表的中间节点

    【题目描述】 给定链表的头节点head,实现删除链表的中间节点的函数。   ...例如:   步删除任何节点;   1->2,删除节点1;   1->2->3,删除节点2;   1->2->3->4,删除节点2;   1->2->3->4-5,删除节点3; 【要求】 如果链表的长度为...(【链表问题】删除单链表中的第K个节点) 其实也是可以使用双指针的,但个人认为,那道题使用双指针的方法并没有我上次那个做法优雅,而这次删除中间节点,则用双指针比较优雅。...问题拓展 题目:删除链表中 a / b 处的节点 【题目描述】   给定链表的头节点 head、整数 a 和 b,实现删除位于 a/b 处节点的函数。   ...例如:   链表:1->2->3->4->5,假设 a/b 的值为 r。

    85940
    领券