数据结构系列之链表——双链表删除

来源:互联网 发布:java二次开发有前途么 编辑:程序博客网 时间:2024/06/07 04:59

(循环判断移动指针、判断相等、分头分中,不等无法删除)

dnode* del(dnode *head,int num){

    //双链表删除值为num的节点

    dnode *p1,*p2;

    p1=head;

    while(p1->data=num&& p1->next!=NULL)

           p1=p1->next;

   

    if(num==p1->data){

           if(p1==head){

                  head=p1->next;

                  head->pre=NULL;

                  free(p1);

           }

           else{

                  p2=p1->pre;

                  p2->next=p1->next;

                  p1->next->pre=p2;

           }

    }

    else printf("nonum\n");

    return head;

}

0 0
原创粉丝点击