点击这里给我发消息 点击这里给我发消息

链表的C语言实现之删除结点

添加时间:2013-12-7
    相关阅读: C语言

假如我们已经知道了要删除的结点p的位置,那么要删除p结点时只要令p结点的前驱结点的链域由存储p结点的地址该为存储p的后继结点的地址,并回收p结点即可。

      以下便是应用删除算法的实例:

    #include <stdio.h>
    #include <malloc.h>
    #include <string.h>
    #define n 10
    typedef struct node
    {
     char name[20];
     struct node *link;
    }stud;

    stud * creat(int n) /*建立新的链表的函数*/
    {
     stud *p,*h,*s;
     int i;
     if((h=(stud *)malloc(sizeof(stud)))==null)
     {
      printf(\"不能分配内存空间!\");
      exit(0);
     }
     h->name[0]=’\\0’;
     h->link=null;
     p=h;
     for(i=0;i<n;i++)
     {
      if((s= (stud *) malloc(sizeof(stud)))==null)
      {
       printf(\"不能分配内存空间!\");
       exit(0);
      }
      p->link=s;
      printf(\"请输入第%d个人的姓名\",i+1);
      scanf(\"%s\",s->name);
      s->link=null;
      p=s;
     }
     return(h);
    }

    stud * search(stud *h,char *x) /*查找函数*/
    {
     stud *p;
     char *y;
     p=h->link;
     while(p!=null)
     {
      y=p->name;
      if(strcmp(y,x)==0)
       return(p);
      else p=p->link;
     }
     if(p==null)
     printf(\"没有查找到该数据!\");
    }

    stud * search2(stud *h,char *x) /*另一个查找函数,返回的是上一个查找函数的直接前驱结点的指针,*/
    /*h为表头指针,x为指向要查找的姓名的指针*/
    /*其实此函数的算法与上面的查找算法是一样的,只是多了一个指针s,并且s总是指向指针p所指向的结点的直接前驱,*/
    /*结果返回s即是要查找的结点的前一个结点*/
    {
     stud *p,*s;
     char *y;
     p=h->link;
     s=h;
     while(p!=null)
     {
      y=p->name;
      if(strcmp(y,x)==0)
       return(s);
      else
      {
       p=p->link;
       s=s->link;
      }
     }
     if(p==null)
      printf(\"没有查找到该数据!\");
    }

    void del(stud *x,stud *y) /*删除函数,其中y为要删除的结点的指针,x为要删除的结点的前一个结点的指针*/
    {
     stud *s;
     s=y;
     x->link=y->link;
     free(s);
    }

    main()
    {
     int number;
     char fullname[20];
     stud *head,*searchpoint,*forepoint;
     number=n;
     head=creat(number);
     printf(\"请输入你要删除的人的姓名:\");
     scanf(\"%s\",fullname);
     searchpoint=search(head,fullname);
     forepoint=search2(head,fullname);
     del(forepoint,searchpoint);
    }

相关链表的C语言实现之删除结点

咨询热线:020-85648757 85648755 85648616 0755-27912581 客服:020-85648756 0755-27912581 业务传真:020-32579052
广州市网景网络科技有限公司 Copyright◎2003-2008 Veelink.com. All Rights Reserved.
广州商务地址:广东省广州市黄埔大道中203号(海景园区)海景花园C栋501室
= 深圳商务地址:深圳市宝源路华丰宝源大厦606
研发中心:广东广州市天河软件园海景园区 粤ICP备05103322号 工商注册