双链表的实现

举报
chenyu 发表于 2021/07/27 01:40:32 2021/07/27
【摘要】 #include <stdio.h>#include <string.h>#include <stdlib.h>#define N 10typedef struct node{ char name[20]; struct node *llink,*rlink;}stud;/*双链表的结构定义*/ /*双链表的创建*/stud * creat...

  
  1. #include <stdio.h>
  2. #include <string.h>
  3. #include <stdlib.h>
  4. #define N 10
  5. typedef struct node
  6. {
  7. char name[20];
  8. struct node *llink,*rlink;
  9. }stud;/*双链表的结构定义*/
  10. /*双链表的创建*/
  11. stud * creat(int n)
  12. {
  13. stud *p,*h,*s;
  14. int i;
  15. if((h=(stud *)malloc(sizeof(stud)))==NULL)
  16. {
  17. printf("cannot find space!\n");
  18. exit(0);
  19. }
  20. h->name[0]='\0';
  21. h->llink=NULL;
  22. h->rlink=NULL;
  23. p=h;
  24. for(i=0;i<n;i++)
  25. {
  26. if((s= (stud *) malloc(sizeof(stud)))==NULL)
  27. {
  28. printf("cannot find space!\n");
  29. exit(0);
  30. }
  31. p->rlink=s;
  32. printf("Please input the %d man's name: ",i+1);
  33. scanf("%s",s->name);
  34. s->llink=p;
  35. s->rlink=NULL;
  36. p=s;
  37. }
  38. h->llink=s;
  39. p->rlink=h;
  40. return(h);

文章来源: chenyu.blog.csdn.net,作者:chen.yu,版权归原作者所有,如需转载,请联系作者。

原文链接:chenyu.blog.csdn.net/article/details/50565072

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。