链表创建,显示,删除和倒置

前端之家收集整理的这篇文章主要介绍了链表创建,显示,删除和倒置前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
  1. 链表创建,显示删除和倒置
  2. #include"stdafx.h"
  3. #include<stdio.h>
  4. #include<malloc.h>
  5. typedefstructdata
  6. {
  7. intData;
  8. structdata*next;
  9. }str;
  10. voidCreate(str**p)
  11. {
  12. *p=(str*)malloc(sizeof(str));
  13. printf("inputthedata:");
  14. scanf("%d",&((*p)->Data));
  15. if((*p)->Data!=0)
  16. {
  17. Create(&((*p)->next));
  18. }
  19. else
  20. {
  21. (*p)->next=NULL;
  22. return;
  23. }
  24. }
  25. voidDisplayList(data*pList)
  26. {
  27. while(pList!=NULL)
  28. {
  29. printf("%d---",pList->Data);
  30. pList=pList->next;
  31. }
  32. }
  33. voidFreeList(data*pList)//释放链表
  34. {
  35. data*temp=pList;
  36. while(temp->Data!=0)
  37. {
  38. pList=pList->next;
  39. free(temp);
  40. temp=NULL;
  41. if(pList->next!=NULL)
  42. temp=pList;
  43. }
  44. }
  45. voidReverseList(data**pList)
  46. {
  47. data*p1=NULL,*p2=NULL,*p3=NULL;
  48. p1=*pList;
  49. p2=p1->next;
  50. while(p2!=NULL)
  51. {
  52. p3=p2->next;
  53. p2->next=p1;
  54. p1=p2;
  55. p2=p3;
  56. }
  57. (*pList)->next=NULL;
  58. (*pList)=p1;
  59. }
  60. voidmain()
  61. {
  62. data*p;
  63. Create(&p);
  64. ReverseList(&p);
  65. DisplayList(p);
  66. FreeList(p);
  67. }
原文链接:https://www.f2er.com/javaschema/288009.html

猜你在找的设计模式相关文章