算法与数据结构--循环链表与双链表

文章介绍了循环链表,特别是单循环链表和双向循环链表的概念,强调了它们如何通过指针结构提高查找首尾元素的效率。在单循环链表中,从任何节点都能高效找到其他节点,而在双链表中,每个节点都有前后指针,进一步加速了对前后节点的访问。此外,文章还提到了双向循环链表的构建和插入删除操作。
摘要由CSDN通过智能技术生成

一.循环链表--尾结点有指针指向首结点
优点:提高查找首尾元素的效率

1.单循环链表/循环链表
【1】概念:在单链表中,将尾结点的指针域NULL改为指向第一个结点,就使整个链表形成一个环,这种首尾详解的链表成为循环链表。

【2】特点:从表中任一结点出发均可找到表中其他结点,提高查找效率。
【2】算法方面:单循环链表上实现表的各种运算的算法与单链表基本一致,只是遍历条件不同。
O单链表p==NULL或p->next==NULL
O循环链表p指向头指针
【3】优点(查找首尾元素的效率提高):
在单链表中用指向表首单元的指针表示一个表,这样就可以在O(1)时间内找到表中的第1个元素。然而要找到表中最后1个元素就要花O(n)的时间遍历整个链表。
在单循环链表中,也可以用指向表首单元的指针表示一个表。但是如果用指向表尾的指针表示一个表,就可以在O(1)的时间内找到表中第一个元素和最后1个元素。

二.双链表--每个结点有两个指针,一个指向前面,一个指向后面
优点:快速找到前面的结点

1.双链表概念与优点


单循环链表中,虽然从表的任意结点出发,都可以找到其前面结点,但需要O(n)时间。
如果希望快速确定表中任一元素的前面一个元素和后面一个元素所在的结点,可以在链表的每个结点中设置两个指针,一个指向后面结点,一个指向前面结点。
形成如下所示的双向链表,简称双链表。

2.双向循环链表

与单链表类似,双链表也可以有循环表。用一个表首结点header将双链表首尾相接,即将表首结点中的left指针指向表尾,并将表尾结点的right指针指向表首哨兵节点。构成如下图所示的双向循环链表。

3.插入与删除操作


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值