数 据 结 构 实 验 指 导 书.docx
- 文档编号:10129197
- 上传时间:2023-02-08
- 格式:DOCX
- 页数:17
- 大小:30.59KB
数 据 结 构 实 验 指 导 书.docx
《数 据 结 构 实 验 指 导 书.docx》由会员分享,可在线阅读,更多相关《数 据 结 构 实 验 指 导 书.docx(17页珍藏版)》请在冰豆网上搜索。
数据结构实验指导书
数据结构实验指导书
计算机学院专业基础教研室
2004年3月
实验一线性表及其应用
一、实验目的
1.熟悉C语言的上机环境,进一步掌握C语言的结构特点。
2.掌握线性表的顺序存储结构的定义及C语言实现。
3.掌握线性表的链式存储结构——单链表的定义及C语言实现。
4.掌握线性表在顺序存储结构即顺序表中的各种基本操作。
5.掌握线性表在链式存储结构——单链表中的各种基本操作。
二、实验内容
1.顺序线性表的建立、插入及删除。
2.链式线性表的建立、插入及删除。
三、实验步骤
1.建立含n个数据元素的顺序表并输出该表中各元素的值及顺序表的长度。
2.利用前面的实验先建立一个顺序表L={21,23,14,5,56,17,31},然后在第i个位置插入元素68。
3.建立一个带头结点的单链表,结点的值域为整型数据。
要求将用户输入的数据按尾插入法来建立相应单链表。
四、实现提示
1.由于C语言的数组类型也有随机存取的特点,一维数组的机内表示就是顺序结构。
因此,可用C语言的一维数组实现线性表的顺序存储。
在此,我们利用C语言的结构体类型定义顺序表:
#defineMAXSIZE 1024
typedef int elemtype; /* 线性表中存放整型元素 */
typedefstruct
{elemtypevec[MAXSIZE];
intlen; /* 顺序表的长度 */
}sequenlist;
将此结构定义放在一个头文件sqlist.h里,可避免在后面的参考程序中代码重复书写,另外在该头文件里给出顺序表的建立及常量的定义。
2.注意如何取到第i个元素,在插入过程中注意溢出情况以及数组的下标与位序(顺序表中元素的次序)的区别。
3.单链表的结点结构除数据域外,还含有一个指针域。
用C语言描述结点结构如下:
typedefintelemtype;
typedefstructnode
{elemtypedata; //数据域
structnode*next;//指针域
}linklist;
注意结点的建立方法及构造新结点时指针的变化。
构造一个结点需用到C语言的标准函数malloc(),如给指针变量p分配一个结点的地址:
p=(linklist*)malloc(sizeof(linklist));该语句的功能是申请分配一个类型为linklist的结点的地址空间,并将首地址存入指针变量p中。
当结点不需要时可以用标准函数free(p)释放结点存储空间,这时p为空值(NULL)。
五、思考与提高
1.如果按由表尾至表头的次序输入数据元素,应如何建立顺序表。
2.在main函数里如果去掉L=&a语句,会出现什么结果?
实验二栈和队列
一、实验目的
1.掌握栈的顺序表示和实现
2.掌握队列的链式表示和实现
二、实验内容
1.编写一个程序实现顺序栈的各种基本运算。
2.实现队列的链式表示和实现。
三、实验步骤
1.初始化顺序栈
2.插入元素
3.删除栈顶元素
4.取栈顶元素
5.遍历顺序栈
6.置空顺序栈
7.初始化并建立链队列
8.入链队列
9.出链队列
10.遍历链队列
四、实现提示
1./*定义顺序栈的存储结构*/
typedefstruct{
ElemTypestack[MAXNUM];
inttop;
}SqStack;
/*初始化顺序栈函数*/
voidInitStack(SqStack*p)
{q=(SqStack*)malloc(sizeof(SqStack)/*申请空间*/)
/*入栈函数*/
voidPush(SqStack*p,ElemTypex)
{if(p->top {p->top=p->top+1; /*栈顶+1*/ p->stack[p->top]=x;} /*数据入栈*/ } /*出栈函数*/ ElemTypePop(SqStack*p) {x=p->stack[p->top];/*将栈顶元素赋给x*/ p->top=p->top-1;}/*栈顶-1*/ /*获取栈顶元素函数*/ ElemTypeGetTop(SqStack*p) {x=p->stack[p->top];} /*遍历顺序栈函数*/ voidOutStack(SqStack*p) {for(i=p->top;i>=0;i--) printf("第%d个数据元素是: %6d\n",i,p->stack[i]);} /*置空顺序栈函数*/ voidsetEmpty(SqStack*p) {p->top=-1;} 2./*定义链队列*/ typedefstructQnode { ElemTypedata; structQnode*next; }Qnodetype; typedefstruct { Qnodetype*front; Qnodetype*rear; }Lqueue; /*初始化并建立链队列函数*/ voidcreat(Lqueue*q) { h=(Qnodetype*)malloc(sizeof(Qnodetype));/*初始化申请空间*/ h->next=NULL; q->front=h; q->rear=h; for(i=1;i<=n;i++)*利用循环快速输入数据*/ { scanf("%d",&x); Lappend(q,x);} /*利用入链队列函数快速输入数据*/ } /*入链队列函数*/ voidLappend(Lqueue*q,intx) {s->data=x; s->next=NULL; q->rear->next=s; q->rear=s;} /*出链队列函数*/ ElemTypeLdelete(Lqueue*q) {p=q->front->next; q->front->next=p->next; if(p->next==NULL) q->rear=q->front; x=p->data; free(p);}/*释放空间*/ /*遍历链队列函数*/ voiddisplay(Lqueue*q) {while(p! =NULL) /*利用条件判断是否到队尾*/ { printf("%d-->",p->data); p=p->next; } } 五、思考与提高 1.读栈顶元素的算法与退栈顶元素的算法有何区别? 2.如果一个程序中要用到两个栈,为了不发生上溢错误,就必须给每个栈预先分配一个足够大的存储空间。 若每个栈都预分配过大的存储空间,势必会造成系统空间紧张。 如何解决这个问题? (1)链栈只有一个top指针,对于链队列,为什么要设计一个头指针和一个尾指针? (2)一个程序中如果要用到两个栈时,可通过两个栈共享一维数组来实现。 即双向栈共享邻接空间。 如果一个程序中要用到两个队列,能否实现? 如何实现? 实验三数组和广义表 一、实验目的 1.掌握稀疏矩阵的压缩存储 2.掌握稀疏矩阵的转置算法 二、实验内容 1.实现上三角阵的压缩存储。 2.用三元组顺序表存储稀疏矩阵,并实现矩阵的转置。 三、实验步骤 1.创建一个数组。 2.输入数据 3.给定矩阵任一元素的下标, 4.打印给定下标所对应的数据。 5.创建三元组顺序表。 6.输入矩阵中的数据。 7.输出对应的矩阵。 四、实现提示 1.对于如下对称矩阵: 将它们存入到一个线性数组中B,不存非零元素,a11存入到第1个位置,a21存入到第二个位置,则aij能存到第几个位置,我们要以用梯形公式算面积。 aij的位置是它上面的元素之和再加上左边的元素之和。 它上面的元素之和为((1+(i-1))×(i-1)/2,左边的元素为(j-1) 所以这个元素存储的位置为k=i(i-1)/2+j-1。 因为矩阵A为对称矩阵,(另一部分没有写出),所以另一部分的元素为 k=j(j-1)/2+i-1. 所以存在关系k=i(i-1)/2+j-1(i>j) 和k=j(j-1)/2+i-1(i 2.结点结构 structtriple{ inti,j;//非零元的行下标和列下标 elemtypee;//非零元数据} 三元组顺序表存储类型 structtsmatrix{ tripledata[12500]; intmu,nu,tu;} 三元顺序表的转置 方法: (1)将矩阵行列互换, (2)重排矩阵 五、思考与提高 1.如何存储三对角阵? 2.如何用行逻辑链接顺序表及十字链表存储稀疏矩阵? 实验四树及二叉树 一、实验目的 1.通过实验,掌握二叉树的建立与存储 2.通过实验,掌握二叉树的遍历方法 二、实验内容 1.练习二叉树的建立与存储 2.练习二叉树的遍历 三、实验步骤 1.建立自己的头文件BT.H,内容包括二叉链表的结构描述、二叉树的建立、二叉树的先序、中序与后序遍历算法。 2.建立二叉树,并通过调用函数,输出先序遍历、中序遍历与后序遍历的结果。 四、实现提示 建立二叉树的代码如下: BTCHINALR *createbt() { BTCHINALR*q; structnode1*s[30]; intj,i,x; printf("建立二叉树,输入结点对应的编号和值,编号和值之间用逗号隔开\n\n"); printf("i,x="); scanf("%d,%c",&i,&x); while(i! =0&&x! ='$') {q=(BTCHINALR*)malloc(sizeof(BTCHINALR)); /*建立一个新结点q*/ q->data=x; q->lchild=NULL; q->rchild=NULL; s[i]=q; /*q新结点地址存入s指针数组中*/ if(i! =1) /*i=1,对应的结点是根结点*/ {j=i/2; /*求双亲结点的编号j*/ if(i%2==0)s[j]->lchild=q;/*q结点编号为偶数则挂在双亲结点j的左边*/ else s[j]->rchild=q;} /*q结点编号为奇数则挂在双亲结点j的右边*/ printf("i,x="); scanf("%d,%c",&i,&x);} return s[1]; /*返回根结点地址*/ } 五、思考与提高 1.如何用孩子兄弟表示法存储树? 2.熟悉并掌握赫夫曼树。 实验五图 一、实验目的 1.掌握图的基本存储方法; 2.掌握有关图的操作算法并用高级语言实现; 3.熟练掌握图的两种搜索路径的遍历方法。 二、实验内容 假设以一个带权有向图表示某一区域的公交线路网,图中顶点代表一些区域中的重要场所,弧代表已有的公交线路,弧上的权表示该线路上的票价(或搭乘所需时间),试设计一个交通指南系统,指导前来咨询者以最低的票价或最少的时间从区域中的某一场所到达另一场所。 三、实验步骤 1.定义结点结构,定义图结构。 2.存储图信息; 3.定义求任意两点最短路径函数; 4.写出主函数。 四、实现提示 typedef struct node { int no; float wgt; struct node *next; }edgenode; typedef struct { char vtx; edgenode *link; }vexnode; typedef vexnode Graph[n]; void Floyd(GraphG,floatA[n][n],intp[n][n]) { int i, j, k;
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数 据 结 构 实 验 指 导 书.docx