- *strong><span style="font-size:14px;">/*
- *Copyright(c)2017,烟台大学计算机学院
- *All right reserved.
- *文件名:main.cpp list.h list.cpp
- *作者:刘浩
- *版本号:v1.0
- *
- *问题描述:建立单链表
- *输入描述:无
- *程序输出:见窗口
- */ </span></strong>
主函数代码如下:
- <pre name="code" class="cpp"><strong>#include <stdio.h>
- #include <malloc.h>
- #include "../list.h"
- int main()
- {
- LinkList *L1, *L2;
- ElemType a[8]= {7, 9, 8, 2, 0, 4, 6, 3};
- CreateListF(L1, a, 8);
- printf("头插法建表结果:");
- DispList(L1);
- CreateListR(L2, a, 6);
- printf("尾插法建表结果:");
- DispList(L2);
- DestroyList(L1);
- DestroyList(L2);
- return 0;
- }
- </strong></pre><br>
- <br>
- <p></p>
- <pre></pre>
- <strong><em><span style="font-size:18px">list.cpp</span></em></strong>
- <p></p>
- <p><strong><span style="font-size:18px"></span></strong></p><pre name="code" class="cpp">#include "stdio.h"
- #include <malloc.h>
- #include "list.h"
- void CreateListF(LinkList *&L,ElemType a[],int n)//头插法建立单链表
- {
- LinkList *s;
- int i;
- L=(LinkList *)malloc(sizeof(LinkList)); //创建头结点
- L->next=NULL;
- for (i=0; i<n; i++)
- {
- s=(LinkList *)malloc(sizeof(LinkList));//创建新结点
- s->data=a[i];
- s->next=L->next; //将*s插在原开始结点之前,头结点之后
- L->next=s;
- }
- }
- void CreateListR(LinkList *&L,ElemType a[],int n)//尾插法建立单链表
- {
- LinkList *s,*r;
- int i;
- L=(LinkList *)malloc(sizeof(LinkList)); //创建头结点
- L->next=NULL;
- r=L; //r始终指向终端结点,开始时指向头结点
- for (i=0; i<n; i++)
- {
- s=(LinkList *)malloc(sizeof(LinkList));//创建新结点
- s->data=a[i];
- r->next=s; //将*s插入*r之后
- r=s;
- }
- r->next=NULL; //终端结点next域置为NULL
- }
- void DestroyList(LinkList *&L) //销毁单链表
- {
- LinkList *p=L,*q=p->next;
- while (q!=NULL)
- {
- free(p);
- p=q;
- q=p->next;
- }
- free(p); //此时q为NULL,p指向尾结点,释放它
- }
- void DispList(LinkList *L) //输出单链表
- {
- LinkList *p=L->next;
- while (p!=NULL)
- {
- printf("%d ",p->data);
- p=p->next;
- }
- printf("\n");
- }<em>
- </em></pre>list.h<p></p>
- <p><strong><span style="font-size:18px"></span></strong></p><pre name="code" class="cpp">#ifndef LIST_H_INCLUDED
- #define LIST_H_INCLUDED
- typedef int ElemType;
- typedef struct LNode //定义单链表结点类型
- {
- ElemType data;
- struct LNode *next; //指向后继结点
- } LinkList;
- void CreateListF(LinkList *&L,ElemType a[],int n);//头插法建立单链表
- void CreateListR(LinkList *&L,ElemType a[],int n);//尾插法建立单链表
- void DestroyList(LinkList *&L); //销毁单链表
- void DispList(LinkList *L); //输出单链表
- #endif // LIST_H_INCLUDED
- </pre> <span style="color:#000066">运行结果如下:</span><p></p>
- <p><strong><span style="font-size:18px"><span style="color:#000066"><br>
- </span></span></strong></p>
- <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>
- </span></span></strong></p>
- <p><strong><span style="font-size:18px"><span style="color:#000066"><br>
- </span> 学习后的总结:</span></strong></p>
- <p><strong><em><span style="font-size:14px">通过此项目,我学会了怎么样定义单链表的存储结构,如何用头插法尾差法建立单链表。为我对以后数据结构的学习打下一个基础。</span></em></strong></p>