数据结构实验报告三

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
L->r[6].key=13;
L->r[7].key=27;
L->r[8].key=49;
L->length=8;
InsertSort(L);
printf("\n\n");
for(i=1;i<=L->length;i++)
printf("%d\n",L->r[i].key);
}
附1:源程序
#define SORT_LIST_MAXSIZE 20
typedef int KeyType;
typedef int InfoType;
typedef struct{
KeyType key;
InfoType otherinfo;
}RcdType;
typedef struct{
RcdType r[SORT_LIST_MAXSIZE+1];
typedef int KeyType;
typedef int InfoType;
typedef struct{
KeyType key;
InfoType otherinfo;
}RcdType;
typedef struct{
RcdType r[SORT_LIST_MAXSIZE+1];
int length;
(3)1~2人为1小组,实验过程中独立操作、相互学习;
四、实验内容及步骤
(一)选择排序算法的实现
1、正确设计程序,并编译、链接成可执行文件
(1)首先正确写出排序顺序表的结构体typedef struct SqList
(2)正确写出选择排序算法SelectSort
(3)写出主程序main,提供输入与输出操作
五、实验小结
实验进行顺利,既了解了排序顺序表的特点,又对选择排序和插入排序算法进行了验证。实验过程中存在以下几个问题:
(1)对指针变量作为参数传递后的操作不是很理解,尤其是形参与实参之间的关系。
(2)对“结构体指针”的“->”操作不是很适应,与一般变量操作相差较大。
经过指导教师的认真帮助以及查阅C程序设计教材,问题基本得以解决,保证了实验的顺利进行。就今后还应进一步加强C语言的学习,掌握一门工具。
本程序的特点是对于用户给定的一组关键字序列(49,38,65,97,76,13,27,49),采用插入排序将其变成一个有序表,并输出排序结果。详见附2。
2、进行程序测试
直接运行可执行文件,观察输出结果,结果正确,如图2所示。
图2
3、算法的时间复杂度分析
本算法为二重循环,基本操作为“比较”与“移动”,二者的时间复杂度均为O(n2),由于二者是顺序结构,因此算法的整体时间复杂度为T(n)= O(n2)。
L->r[j+1]=L->r[j];
L->r[j+1]=L->r[0];
}
}
main()
{
SortList *L;
int i;
L->r[0].key=0;
L->r[1].key=49;
L->r[2].key=38;
L->r[3].key=65;
L->r[4].key=97;
L->r[5].key=76;
}SortList;
void InsertSort(SortList *L)
{
int i,j;
for(i=2;i<=L->length;i++)
if(L->r[i].key<L->r[i-1].key){
L->r[0]=L->r[i];
for(j=i-1;L->r[0].key<L->r[j].key;j--)
由于二者是顺序结构,因此算法的整体时间复杂度为T(n)= O(n2)。
(二)插入排序算法的实现
1、正确设计程序,并编译、链接成可执行文件
(1)首先正确写出排序顺序表的结构体typedef struct SqList
(2)正确写出插入排序算法InsertSort
(3)写出主程序main,提供输入与输出操作
int length;
}SortList;
void SelectSort(SortList *L)
{
RcdType W;
int i,j,k;
for(i=1;i<L->length;i++){
j=i;
for(k=i+1;k<=L->length;k++)
if(L->r[k].key<L->r[j].key) j=k;
本程序的特点是对于用户给定的一组关键字序列(49,38,65,49,76,13,27,52),采用选择排序将其变成一个有序表,并输出排序结果。详见附1。
2Байду номын сангаас进行程序测试
直接运行可执行文件,观察输出结果,结果正确,如图1所示。
图1
3、算法的时间复杂度分析
本算法为二重循环,基本操作为“比较”与“交换”,二者的时间复杂度均为O(n2),
if(i!=j){
W=L->r[j];
L->r[j]=L->r[i];
L->r[i]=W;
}
}
}
main()
{
SortList *L;
int i;
L->r[0].key=0;
L->r[1].key=49;
L->r[2].key=38;
L->r[3].key=65;
L->r[4].key=49;
L->r[5].key=76;
《数据结构》实验报告
一、实验名称
实验三:排序
二、实验目的
通过本实验,加深对排序概念的理解,能够对三类不同排序方法进行复杂度分析。掌握简单排序方法、先进排序方法和基数排序方法的变化过程及算法设计与分析。
三、实验要求
(1)学生提前准备好实验报告,预习并熟悉实验步骤;
(2)遵守实验室纪律,在规定的时间内完成要求的内容;
L->r[6].key=13;
L->r[7].key=27;
L->r[8].key=52;
L->length=8;
SelectSort(L);
printf("\n\n");
for(i=1;i<=L->length;i++)
printf("%d\n",L->r[i].key);
}
附2:原程序
#define SORT_LIST_MAXSIZE 20
相关文档
最新文档