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

  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. }

相关文章

什么是设计模式一套被反复使用、多数人知晓的、经过分类编目...
单一职责原则定义(Single Responsibility Principle,SRP)...
动态代理和CGLib代理分不清吗,看看这篇文章,写的非常好,强...
适配器模式将一个类的接口转换成客户期望的另一个接口,使得...
策略模式定义了一系列算法族,并封装在类中,它们之间可以互...
设计模式讲的是如何编写可扩展、可维护、可读的高质量代码,...