第四周线性表(二)--链表 项目一 建立单链表

  1. *strong><span style="font-size:14px;">/*   
  2. *Copyright(c)2017,烟台大学计算机学院   
  3. *All right reserved.   
  4. *文件名:main.cpp list.h list.cpp   
  5. *作者:刘浩 
  6. *版本号:v1.0   
  7. *   
  8. *问题描述:建立单链表   
  9. *输入描述:无   
  10. *程序输出:见窗口   
  11. */ </span></strong>  

 

主函数代码如下:

[cpp]  view plain  copy
  1. <pre name="code" class="cpp"><strong>#include <stdio.h>  
  2. #include <malloc.h>  
  3. #include "../list.h"  
  4.   
  5.   
  6. int main()  
  7. {  
  8.     LinkList *L1, *L2;  
  9.     ElemType a[8]= {7, 9, 8, 2, 0, 4, 6, 3};  
  10.     CreateListF(L1, a, 8);  
  11.     printf("头插法建表结果:");  
  12.     DispList(L1);  
  13.     CreateListR(L2, a, 6);  
  14.     printf("尾插法建表结果:");  
  15.     DispList(L2);  
  16.     DestroyList(L1);  
  17.     DestroyList(L2);  
  18.     return 0;  
  19. }  
  20. </strong></pre><br>  
  21. <br>  
  22. <p></p>  
  23. <pre></pre>  
  24. <strong><em><span style="font-size:18px">list.cpp</span></em></strong>  
  25. <p></p>  
  26. <p><strong><span style="font-size:18px"></span></strong></p><pre name="code" class="cpp">#include "stdio.h"  
  27. #include <malloc.h>  
  28. #include "list.h"  
  29.   
  30. void CreateListF(LinkList *&L,ElemType a[],int n)//头插法建立单链表  
  31. {  
  32.     LinkList *s;  
  33.     int i;  
  34.     L=(LinkList *)malloc(sizeof(LinkList));     //创建头结点  
  35.     L->next=NULL;  
  36.     for (i=0; i<n; i++)  
  37.     {  
  38.         s=(LinkList *)malloc(sizeof(LinkList));//创建新结点  
  39.         s->data=a[i];  
  40.         s->next=L->next;            //将*s插在原开始结点之前,头结点之后  
  41.         L->next=s;  
  42.     }  
  43. }  
  44. void CreateListR(LinkList *&L,ElemType a[],int n)//尾插法建立单链表  
  45. {  
  46.     LinkList *s,*r;  
  47.     int i;  
  48.     L=(LinkList *)malloc(sizeof(LinkList));     //创建头结点  
  49.     L->next=NULL;  
  50.     r=L;                    //r始终指向终端结点,开始时指向头结点  
  51.     for (i=0; i<n; i++)  
  52.     {  
  53.         s=(LinkList *)malloc(sizeof(LinkList));//创建新结点  
  54.         s->data=a[i];  
  55.         r->next=s;          //将*s插入*r之后  
  56.         r=s;  
  57.     }  
  58.     r->next=NULL;           //终端结点next域置为NULL  
  59. }  
  60.   
  61. void DestroyList(LinkList *&L)  //销毁单链表  
  62. {  
  63.     LinkList *p=L,*q=p->next;  
  64.     while (q!=NULL)  
  65.     {  
  66.         free(p);  
  67.         p=q;  
  68.         q=p->next;  
  69.     }  
  70.     free(p);    //此时q为NULL,p指向尾结点,释放它  
  71. }  
  72.   
  73. void DispList(LinkList *L)  //输出单链表  
  74. {  
  75.     LinkList *p=L->next;  
  76.     while (p!=NULL)  
  77.     {  
  78.         printf("%d ",p->data);  
  79.         p=p->next;  
  80.     }  
  81.     printf("\n");  
  82. }<em>  
  83. </em></pre>list.h<p></p>  
  84. <p><strong><span style="font-size:18px"></span></strong></p><pre name="code" class="cpp">#ifndef LIST_H_INCLUDED  
  85. #define LIST_H_INCLUDED  
  86. typedef int ElemType;  
  87. typedef struct LNode        //定义单链表结点类型  
  88. {  
  89.     ElemType data;  
  90.     struct LNode *next;     //指向后继结点  
  91. } LinkList;  
  92.   
  93. void CreateListF(LinkList *&L,ElemType a[],int n);//头插法建立单链表  
  94. void CreateListR(LinkList *&L,ElemType a[],int n);//尾插法建立单链表  
  95. void DestroyList(LinkList *&L); //销毁单链表  
  96. void DispList(LinkList *L); //输出单链表  
  97.   
  98.   
  99. #endif // LIST_H_INCLUDED  
  100. </pre> <span style="color:#000066">运行结果如下:</span><p></p>  
  101. <p><strong><span style="font-size:18px"><span style="color:#000066"><br>  
  102. </span></span></strong></p>  
  103. <p><strong><span style="font-size:18px"><span style="color:#000066"><img src="https://img-blog.csdn.net/20171026104947078?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaHVhbmdTUzIwMTY1ODUwNjIyNg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt=""><br>  
  104. </span></span></strong></p>  
  105. <p><strong><span style="font-size:18px"><span style="color:#000066"><br>  
  106. </span> 学习后的总结:</span></strong></p>  
  107. <p><strong><em><span style="font-size:14px">通过此项目,我学会了怎么样定义单链表的存储结构,如何用头插法尾差法建立单链表。为我对以后数据结构的学习打下一个基础。</span></em></strong></p>  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值