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

  1. /* 
  2. *Copyright (c)2016,烟台大学计算机与控制工程学院 
  3. *All rights reserved. 
  4. *文件名称:项目1.cpp 
  5. *作    者:陈鹏鹏 
  6. *完成日期:2016年9月22日 
  7. *版 本 号:v1.0 
  8. *问题描述:定义单链表存储结构,用头插法和尾插法建立单链表,并显示建立好以后的结果。 
  9. *输入描述:无 
  10. *程序输出:输出头插法尾插发链表 
  11. */  #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;
        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");
    }
  12. 运行结果:

  13. 总结:通过这次编写我知道了单链表的一些用法,从刚开始的不太懂到了可以简单的使用,这也是我的收获。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Cortex-M3是一种32位的嵌入式微控制器,具有高性能和低功耗的特点。单链表是一种常用的数据结构,用于存储和管理数据。 在使用Cortex-M3单链表时,我们首先需要定义链表节点结构。节点包含两个成员:一个存储数据的变量和一个指向下一个节点的指针。我们可以使用结构体来定义节点并在内存进行分配。 接下来,我们需要定义一个指向第一个节点的指针,并将其初始化为NULL,表示链表为空。随后,我们可以通过节点的指针操作来对链表进行插入、删除和遍历等操作。 插入操作可以在链表的开头或者末尾插入一个新节点。首先,我们需要为新节点分配内存,并将数据存储在新节点的变量。然后,我们可以更新节点指针,将新节点插入链表的相应位置。 删除操作可以根据节点的指针来删除链表节点。我们需要先保存要删除节点的前一个节点的指针,并将其指向删除节点的下一个节点。然后,我们可以释放删除节点所占用的内存,并更新链表的指针。 遍历操作可以按照链表的顺序依次访问每个节点,并进行相应的操作。我们可以利用一个循环来实现节点的遍历,从链表的第一个节点开始,直到最后一个节点。 通过使用Cortex-M3单链表,我们可以方便地存储和管理数据。单链表的插入、删除和遍历操作都是基于节点指针的操作,使得我们可以高效地操作链表数据。然而,需要注意的是,在使用链表时,我们需要正确地管理内存分配和释放,以避免内存泄漏和其他问题的发生。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值