欢迎来到天天文库
浏览记录
ID:41614525
大小:112.17 KB
页数:8页
时间:2019-08-28
《实验一线性表及其应用(I)》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、实验项目线性表及其应用(1)实验内容1.实现线性表的顺序存储结构和主要的革本操作,并添加输出显示等辅助函数,在此基础上实现后续两个算法。线性表的抽象数据类型定义参见教材第19页。顺序存储结构的定义参见教材第22页。2.设线性表存放于顺序表A中,其中有n个元素,且递增有序,请设计一算法,将x插入到线性表的适当位置,以保持线性表的有序性。(题集第17页2.11)3.试写一算法,实现顺序表的就地逆置,即利用原表的存储空间将线性表(al,a2,…,an)逆置为(an,an-l,…,al)。(题集第18页2.21)算法设计与程序实现:■/—-X1法分析本次
2、实验的冃的是理解和掌握线性表顺序存储结构的川法,要解决两个基本问题一是将元素插入到有序的顺序表屮,并保持线性表的有序性;二是实现顺序表的就地逆置。首先需插入元素的顺序表是有序的,故需先将输入的线性表元素进行排序,至于数据排序,我选择的是起泡排序算法,而实现插入元素到顺序表,则是将待插入的元素与已排序的顺序表中的每个元素进行比较进而确定插入位置;实验内容二的就地逆置则仅仅只需用一个foi•循环将顺序表中对称位置处的元素交换即可。程序设计流程图如下所示:开始核此程序屮用到的白己编写的头文件以在下面给出,而头文件的说明则在主函数中文件包含部分的注释处,
3、核心程序如F:1.主函数如下:心#include"stdafx.h"//标准输入输出函数头文件#includeindows・h〃//emd窗口设置函数头文件^include"ADT.h"//数据结构中相关结构体类型定义及相关数据类型定义序^include^DataStructurC-LinearList.h"//数据结构第二*:线性表屮相关函数的定义及声明intmain()tsystemCtitle数据结构实验实验名称:线性表及其应用(1)0;//设置emd窗口标题systemC'colorFl〃);//设置控制台窗口的背景色和前景色system
4、(,zdate/T");//输出当前的日期system("TIME/T");〃输出当前的时间inti,DIR;//控制变量intLISTJfAX;//表长ElemTypedata;//待插入元索SqListL;〃定义SqList类型变量lnitList_Sq(L);//初始化顺序衣printf(z,^1.请输入所需建立的线性表的长度:“);scanf_s("%d",&LISTJAX);printf("探2.请录入数据:");for(i=0;i5、L.length;//表长自增1}printfC探3.请选择数据的排序方式(0:递减,1:递增):“);scanf_s("%d",&DIR);if(DIR){BubbleSortList_Sq(L,INCREASE);〃将顺序表递增排序printfC※久数据递增排列:“);}else{BubbleSortList_Sq(L,DECREASE);〃将顺序表递减排序printfC※久数据递减排列:“);}PrintfList_Sq(L);//打印输出printfC※厶.请输入待插入的元素:”);scanf_s(,,%d,,>&data);Inse6、rtSequentList^Sq(L,data);//将数据元素插入到顺序表1・屮printfC沁插入元素后的顺序表:");PrintfList_Sq(L);//打印输出InverseList^Sq(L);//将顺序表就地逆置printfC^7.就地逆置后的顺序表:〃);PrintfList_Sq(L);//打卬输出printf("");return0:)2.头文件"ADT.屮的部分程序如下:#ifndefADT_H_#defineADT_H_:rj%rj%xprj%rj%rjwrj%rj%rj%rj%rj%rj%rj%rjwrj%r7、j%*常量和数据类型预定义%W■丄"■丄"•丄"■加■丄.•丄“•丄.xtx■加■丄"■丄"■["■["•丄“■丄"■加■加%(X■士■加■加ff/*函数结杲状态代码*/SdcfineTRUE1#defineFALSE#defineOK#defincERROR#defineINFEASIBLE#defineOVERFLOW-2-排序方式状态^defineINCREASE^defineDECREASE/*数据类型预定义*/〃递增〃递减-*/typedefintStatus;//函数结果状态类型typedefint_bool;//bool状态类型■丄8、"■丄"U"■丄*£“■丄"■丄.U"■士"■丄"■丄"■丄"■丄".加■丄"■丄"■丄"■丄"kA*■丄"■土.加.加fVJ彳、数据结
5、L.length;//表长自增1}printfC探3.请选择数据的排序方式(0:递减,1:递增):“);scanf_s("%d",&DIR);if(DIR){BubbleSortList_Sq(L,INCREASE);〃将顺序表递增排序printfC※久数据递增排列:“);}else{BubbleSortList_Sq(L,DECREASE);〃将顺序表递减排序printfC※久数据递减排列:“);}PrintfList_Sq(L);//打印输出printfC※厶.请输入待插入的元素:”);scanf_s(,,%d,,>&data);Inse
6、rtSequentList^Sq(L,data);//将数据元素插入到顺序表1・屮printfC沁插入元素后的顺序表:");PrintfList_Sq(L);//打印输出InverseList^Sq(L);//将顺序表就地逆置printfC^7.就地逆置后的顺序表:〃);PrintfList_Sq(L);//打卬输出printf("");return0:)2.头文件"ADT.屮的部分程序如下:#ifndefADT_H_#defineADT_H_:rj%rj%xprj%rj%rjwrj%rj%rj%rj%rj%rj%rj%rjwrj%r
7、j%*常量和数据类型预定义%W■丄"■丄"•丄"■加■丄.•丄“•丄.xtx■加■丄"■丄"■["■["•丄“■丄"■加■加%(X■士■加■加ff/*函数结杲状态代码*/SdcfineTRUE1#defineFALSE#defineOK#defincERROR#defineINFEASIBLE#defineOVERFLOW-2-排序方式状态^defineINCREASE^defineDECREASE/*数据类型预定义*/〃递增〃递减-*/typedefintStatus;//函数结果状态类型typedefint_bool;//bool状态类型■丄
8、"■丄"U"■丄*£“■丄"■丄.U"■士"■丄"■丄"■丄"■丄".加■丄"■丄"■丄"■丄"kA*■丄"■土.加.加fVJ彳、数据结
此文档下载收益归作者所有