第四周:项目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):建立单链表

问题及代码: /* *烟台大学计算机与控制工程学院 *作 者:杨宁 *完成日期:2015年9月21日 *问题描述:定义单链表存储结构,用头插法和尾插法建立...
  • yn2333
  • yn2333
  • 2015年09月21日 16:41
  • 152

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

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

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

/* Copyright (c)2016,烟台大学计算机与控制工程学院 All rights reserved. 文件名称:项目...
  • wman1997
  • wman1997
  • 2016年09月22日 11:08
  • 83

(第四周项目1)建立单链表

定义单链表存储结构,用头插法和尾插法建立单链表,并显示建立好以后的结果。 请在下面代码的基础上开展工作: #include #include typedef int ElemType; ...
  • suzucheese
  • suzucheese
  • 2015年10月05日 16:11
  • 211

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

/*         Copyright (c)2016,烟台大学计算机与控制工程学院         All rights reserved.         文件名称:wu.cpp        ...
  • wuhao5211314
  • wuhao5211314
  • 2016年09月22日 10:22
  • 76

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

/*烟台大学计算机学院   文件名称:LinkList   作者:董玉祥   完成日期: 2017 10 6   问题描述:定义单链表存储结构,用头插法和尾插法建立单链表,并显示建立好以后的结果  ...
  • dongyuxiangi
  • dongyuxiangi
  • 2017年10月06日 10:58
  • 87

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

Copyright(c) 2017,烟台大学计算机学院 All rights reserved. 文件名称:text.cpp 作者:黄潇慧 完成日期:2017年9月19日 版本:v...
  • ff2333
  • ff2333
  • 2017年09月21日 10:44
  • 56

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

/* * Copyright (c) 2017,烟台大学计算机学院 * All right reserved. * 文件名称:main.cpp * 作者:...
  • wanghuahui1
  • wanghuahui1
  • 2017年09月27日 10:26
  • 64

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

项目名称:第四周项目1——建立单链表 作者:江楠 完成时间:2015年10月9日 问题描述:定义单链表存储结构,用头插法和尾插法建立单链表,并显示建立好后的结果 #include #inc...
  • AegeanS1011
  • AegeanS1011
  • 2015年10月09日 09:10
  • 191

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

/* *Copyright (c)2017,烟台大学计算机与控制工程学院 *All rights reserved. *文件名称:8.cpp *作 者:尚文哲 *完成日期:2017年9...
  • swzzz
  • swzzz
  • 2017年09月21日 10:13
  • 50
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:第四周:项目1——建立单链表
举报原因:
原因补充:

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