双向链表知识总结

双向链表

双向链表也叫双链表,是链表的一种,它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱。所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继结点。一般我们都构造双向循环链表。

  • 数据域,两个指针域
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
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

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值