第四周项目1—建立单链表

问题:

/*
*Copyright (c)2015,烟台大学计算机与控制工程学院
*All rights reserved.
*文件名称:项目1.cbp
*作    者:李艺
*完成日期:2015年9月21日
*版 本 号:v1.0
*
*问题描述:定义单链表存储结构,用头插法和尾插法建立单链表,并显示建立好以后的结果。
*输入描述:无
*程序输出:输出头插法尾插发链表
*/

#include <stdio.h>
#include <malloc.h>
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)  ;//输出单链表

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;
}
//在下面写自定义函数(实现相关算法)的代码

void CreateListF(LinkList *&L,ElemType a[],int n)//头插法建立单链表
{
    LinkList *s,*r;
    int i;
    L=(LinkList *)malloc(sizeof(LinkList));//创建头节点
    r=L;                                   //r始终指向尾节点,开始时指向头结点
    for (i=0;i<n;i++)                      //循环建立数据节点
    {
        s=(LinkList *)malloc(sizeof(LinkList));//创建新结点
        s->data=a[i];                      //创建数据节点*s
        r->next=s;                         //将*s插入到*r之后
        r=s;
    }
    r->next=NULL;                          //尾节点next域置于NULL
}
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;   //p指向*q的前驱节点
    while (q!=NULL)             //循环判断 逐个销毁
    {
        free(p);                //释放*p节点
        p=q;                    //p、q同步后移一个节点
        q=p->next;              //再赋值
    }
    free(p);    //此时q为NULL,p指向尾结点,释放它
}

void DispList(LinkList *L)  //输出单链表
{
    LinkList *p=L->next;        //p指向开始节点
    while (p!=NULL)             //p不为NULL,输出*p节点的date域
    {
        printf("%d ",p->data);
        p=p->next;              //p移向下一个节点
    }
    printf("\n");
}


运行结果:

 

 

 

知识点总结:

      学习了链表的两个建立方法。

 

学习心得:

     对于链表的建立虽然理解但还是不熟悉,要勤加练习。

阅读更多
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/ly201458506115/article/details/48629555
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭