第4周项目1 - 建立单链表
来源:互联网 发布:手机版分类信息源码 编辑:程序博客网 时间:2024/05/18 01:04
/*Copyright (c) 2015, 烟台大学计算机与控制工程学院 * All rights reserved. * 文件名称:H1.cpp * 作者:辛志勐 * 完成日期:2015年9月21日 * 版本号:vc6.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); //输出单链表
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 DispList(LinkList *L) //输出单链表
{
LinkList *p=L->next;
while (p!=NULL)
{
printf("%d ",p->data);
p=p->next;
}
printf("\n");
}
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);
return 0;
}
知识点总结:头插法建立线性表,尾插法建立线性表。
学习心得:目前我的学习程度只能够看懂原有的代码,脱离原码以后自己并不能正确编译,以后还得加强练习。
- 第4周 项目1-建立单链表
- 第4周项目1 - 建立单链表
- 第4周项目1-建立单链表
- 第4周项目1-建立单链表
- 【第4周 项目1 - 建立单链表】
- 第4周 项目1 - 建立单链表
- 第4周项目1-建立单链表
- 第4周 项目1 - 建立单链表
- 第4周项目1建立单链表
- 第4周项目1 建立单链表
- 第4周项目1 建立单链表
- 第4周项目1建立单链表
- 第4周项目1-建立单链表
- 第4周 项目1-- 建立单链表
- 第4周项目1-建立单链表
- 第4周项目1 -建立单链表
- 第4周项目1-建立单链表
- 【第4周 项目1-建立单链表 】
- 关于Predicate<T>委托
- 判断JS对象是否拥有某属性
- windows远程(xrdp+vnc)连接ubuntu linux
- 详细解析JavaFX的键盘事件KeyEvent - Pressd/Released/Typed
- Effective C++——资源管理
- 第4周项目1 - 建立单链表
- 顺序表:两集合的交集
- Myeclipse 10 Maven 构建 Java Web 项目
- 初学nodejs,典型demo
- 第三周——项目2建设“顺序表”算法库
- 项目二——建设“单链表”的算法库
- 小强的HTML5移动开发之路(7)——坦克大战游戏1
- DBCP针对不同数据库的validationQuery
- 备忘:连接数据库的写法