双向链表
双向链表也叫双链表,是链表的一种,它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱。所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继结点。一般我们都构造双向循环链表。
- 数据域,两个指针域
typedef struct node
{
int data;
struct node *prior,*next;
}dlinklist;
- 初始化双向链表
int Init_dlinklist(dlinklist * head,dlinklist * tail)
{
head=(dlinklist*)malloc(sizeof(dlinklist ));
tail=(dlinklist*)malloc(sizeof(dlinklist ));
if(!head||!tail) //如果head 或者 tail有一个位空
return 0;
/*这一步很关键*/
head->prior=NULL;
tail->next=NULL;
/*链表为空时让头指向尾*/
head->next=tail;
tail->prior=head;
return 1;
}
- 建立双向链表
Createlink(dlinklist *head,dlinklist *tail,int a[],int n){
dlinklist *pmove=tail,*pinsert;
for(int i=0;i<n;i++){
pinsert=(dlinklist *)malloc(sizeof(dlinklist));
pinsert->data=a[i];
pinsert->next=NULL;
pinsert->prior=NULL;
pmove->prior->next=pinsert; //插入语句
pinsert->prior=pmove->prior;
pinsert->next=pmove;
pmove->prior=pinsert;
pmove=pmove->prior;
}
}
- 双向链表的输出
Printlist(dlinklist *head,dlinklist *tail){
dlinklist *pmove;
pmove=head->next;
while(pmove!=tail){
printf("%5d",pmove->data);
pmove=pmove->next;
}
printf("\n");
}
- 双向链表的删除
p->prior->next=p->next;
p->next->prior=p->prior;
free(p);
- 双向链表的插入
s->prior=p;
s->next=p->next;
p->next->prior=s;
p->next=s;
可是为什么市场上单链表的使用多于双链表呢?
从存储结构来看,每个双链表的节点要比单链表的节点多一个指针,而长度为n就需要 n*length(这个指针的length在32位系统中是4字节,在64位系统中是8个字节) 的空间,这在一些追求时间效率不高应用下并不适应,因为它占用空间大于单链表所占用的空间;这时设计者就会采用以时间换空间的做法,这时一种工程总体上的衡量。https://blog.youkuaiyun.com/kangxidagege/article/details/80211225