数据结构——线性表(双链表、循环链表、静链表)

双链表

单链表只有一个后继指针,所以只能从头节点依次向后遍历。要访问某个节点的前驱节点,只能从头开始遍历。访问后继节点时间复杂度为O(1),访问前驱节点为O(n)。
为了克服这个缺点,引入双链表。
1、双链表单个节点。

priordatanext
prior为前驱指针域data为数据域next为后继指针域

节点类型描述如下:

typedef struct DNode{
	ElemType data;
	struct DNode *prior,*next;
}DNode,*LinkList;

2、双链表的基本操作

插入操作

s->next=p->next;
p->next->prior=s;
s->prior=p;
p->next=s;
//第1、2步必须在第4步之前

删除操作

p-next=q->next;
q-next-prior=p;
free(q);

循环链表

循环单链表
设尾指针操作效率更高
若L->next==L,链表为空。

循环双链表
若L->nextL&&L->priorL,链表为空。

静态链表

通过数组实现存储结构的单链表
考点,但是不常用
链表描述:

#define MaxSize 50
typedef struct{
	ElemType data;
	int next;
}SLinkList[MaxSize];
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值