第四周 项目1——建立单链表
来源:互联网 发布:js框架有哪些 编辑:程序博客网 时间:2024/06/07 15:33
- /*
- Copyright (c)2016,烟台大学计算机与控制工程学院
- All rights reserved.
- 文件名称:wu.cpp
- 作 者:武昊
- 完成日期:2016年9月22日
- 版 本 号: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;
- 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");
- }
- 知识点总结:
- 学习了头插法和尾插法两种链表建立的方法,使我们更快速方便的建立链表。
0 0
- 第四周项目1—建立单链表
- 第四周—项目1 建立单链表
- 第四周项目1—建立单链表
- 第四周—项目1 建立单链表
- 第四周项目1—建立单链表
- 第四周项目1—建立单链表
- 第四周项目1—建立单链表
- 第四周项目1—建立单链表
- 第四周项目1 —建立单链表
- 第四周项目1—建立单链表
- 第四周项目一—建立单链表
- 第四周项目—建立单链表
- 第四周——【项目1 - 建立单链表】
- 第四周上机实践项目1——建立单链表
- 第四周上机实践—项目1—建立单链表
- 第四周项目1——建立单链表
- 第四周:项目1——建立单链表
- 第四周项目1——建立单链表
- Page Visibility API 页面可见性
- tar 指令应用出错 及 tar 指令参数详解
- Spring+Mybatis多数据源的实现
- 第四周--项目3-单链表应用3
- 【HDU5895 2016 ACM ICPC Asia Regional Shenyang Online D】【公式转化 矩阵快速幂 欧拉定义】Mathematician QSC 递推数列前n平方项和
- 第四周 项目1——建立单链表
- Servlet+JavaBean+MySQL实现用户登录认证
- Java interrupt相关问题
- 【日常踩坑】kindle设备收不到qq邮箱发送的文件
- 从零开始学习音视频编程技术(七) FFMPEG Qt视频播放器之SDL的使用
- 第四周-C语言 电阻计算
- 第四周项目一
- StoryBoard中tableview约束被误删的后果
- binutils安装步骤