线性表的链式表示--双链表

本文介绍了双链表的概念,它弥补了单链表访问前驱结点时间复杂度高的问题。双链表包含前后两个指针,用于指向相邻结点。文中详细讲解了双链表的初始化、后插入、后删除操作,并讨论了遍历方法,包括后向和前向遍历。此外,提到了在特定情况下如插入和删除最后一个结点时需要注意的细节。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

0.双链表
1.双链表–初始化
2.双链表–插入 (后插)
3.双链表–删除 (后删)
4.双链表–遍历


0.双链表

  • 单链表只能从头结点依次顺序向后遍历,若要访问某个前驱节点,只能从头遍历。
  • 单链表访问后继结点时间复杂度为O(1),访问前驱结点时间复杂度为O(n)。
  • 为克服单链表的缺点,引入了双链表。双链表有两个指针:prior(指向其前驱结点)、next(指向其后继结点)。
  • 双链表不可随机存取,按位查找、按值查找时间复杂度为O(n),只能用遍历的方式。

1.双链表–初始化(带头结点)

  • 判空(带头结点)
    在这里插入图片描述
//判断双链表是否为空(带头结点)
bool Empty(DLinklist L){
	if(L->next == NULL)
		return true;
	else 
		return false;
}

2.双链表–插入(后插)

  • 在 p 结点之后插入 s 结点
    在这里插入图片描述
//在 p 结点之后插入 s 结点
//代码 1
bool InsertNextDNode(DNode *p,DNode *s){
	s->next = p->next;
	p->next->prior = s;
	s->prior = p;
	p->next = s;
}

but 如果 p 是最后一个结点。。此代码需要改进 如下:

//在 p 结点之后插入 s 结点
//代码 2
bool InsertNextDNode(DNode *p,DNode *s){
	if(p == NULL || s == NULL)  //非法参数
		return false;
//出入过程的关键步骤    需要注意插入的顺序 		
	s->next = p->next;
	if(p->next != NULL)
		p->next->prior = s;
	s->prior = p;
	p->next = s;
	return true;
}

3.双链表–删除(后删)

  • 删除 p 的后继结点 q
    删除 p 的后继结点 q
//删除 p 的后继结点 q
p->next = q->next;
q->next->prior = p;
free(q);

同上,如果被删结点是最后一个结点,需特殊处理。。此代码需要改进

4.双链表–遍历

  • 后向遍历
while(p!=NULL){
p = p->next;
}
  • 前向遍历
while(p!=NULL){
p = p->prior;
}
  • 前向遍历(跳过头节点)
while(p->prior!=NULL){
p = p->prior;
}

1.本博客供个人学习使用
2.结合王道数据结构复习指导书

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值