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

原创 2015年11月20日 08:54:59
01./* 
02.*Copyright (c)2015,烟台大学计算机与控制工程学院 
03.*All rights reserved. 
04.*文件名称:项目1.cpp 
05.*作    者:孙立立 
06.*完成日期:2015年11月20日 
07.*版 本 号:v1.0 
08.* 
09.*问题描述:定义单链表存储结构,用头插法和尾插法建立单链表,并显示建立好以后的结果。 
10.*输入描述:无 
11.*程序输出:输出头插法尾插发链表 
12.*/  
13.  

运行程序如下:
#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");
}


运行结果:

相关文章推荐

第四周项目1 建立单链表

问题描述及代码: /* *烟台大学计控学院 *作 者:王力源 *完成日期:2016年9月22日 *问题描述:定义单链表存储结构,用头插法和尾插法...

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

问题及代码: /* *烟台大学计算机控制与工程学院 *作 者:刘倩 *lu完成日期:2016年9月18日 *问题描述:定义单链表存储结构,用头插法和尾...

【第四周项目1-建立单链表】

问题及代码: /* * Copyright (c) 2016, 烟台大学计算机与控制工程学院 * All rights reserved. * 文件名称:Cube007.cpp * 作 ...

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

问题及代码: /* *Copyright(c)2015,烟台大学计算机与控制工程学院 *All right reserved. *文件名称:main.cpp *作者:程昂 *完成日期;20...
  • luguoca
  • luguoca
  • 2015年09月21日 16:33
  • 316

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

/*Copyright(c)2016,烟台大学计算机与控制工程学院   *All right reserved.   *文件名称:头插法和尾插法.cpp   *作者:陈晓琳   *完成日期;2...

第四周项目1 建立单链表

问题代码: /* copyright (t) 2016,烟台大学计算机学院 *All rights reserved. *文件名称:ll.cpp *作者:李玲 *完成日...

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

问题及代码: Copyright (c)2016,烟台大学计算机与控制工程学院   All rights reserved.   文件名称:项目1.cpp   作    者:董雪   完成日期:201...
  • vip____
  • vip____
  • 2016年09月19日 20:17
  • 124

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

问题: /* *Copyright (c)2016,烟台大学计算机与控制工程学院 *All rights reserved. *文件名称:项目1.cpp *作 者:杨雅鑫 *完成日...

第四周项目1 建立单链表

/* *Copyright (c)2015,烟台大学计算机与控制工程学院 *All rights reserved. *文件名称:项目1.cpp *作 者:佟兴锋 *完成日期:2015年10月3...

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

问题及代码: /* Copyright (c)2016,烟台大学计算机与控制工程学院 All rights reserved. 文件名称:顺序表的应用.cpp...
  • Aoutlaw
  • Aoutlaw
  • 2016年09月18日 11:02
  • 136
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:第四周:项目1——建立单链表
举报原因:
原因补充:

(最多只允许输入30个字)