- 1、本文档共16页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第 PAGE \* Arabic 8 页
实验九 排序
9.1 实验目的:
熟悉掌握各种排序方法,深刻理解排序算法及其执行的过程;
学会分析各种排序算法的性能;
了解各种方法的优缺点,对于实际问题能够选择一种较好的排序方案。
9.2 实验要求:
复习课本中有关排序的知识;
用C语言完成算法和程序设计并上机调试通过;
撰写实验报告,给出算法思路或流程图和具体实现(源程序)、算法分析结果(包括时间复杂度、空间复杂度以及算法优化设想)、输入数据及程序运行结果(必要时给出多种可能的输入数据和运行结果)。
9.3 基础实验
[实验1] 实现直接插入排序算法
实验内容与要求:
编写一个程序实现直接插入排序过程,并输出{9,8,7,6,5,4,3,2,1,0}的排序过程。
分析:
算法思想参照课本。
参考程序:
#include stdio.h
#define MAXE 20 /*线性表中最多元素个数*/
typedef int KeyType;
typedef char InfoType[10];
typedef struct /*记录类型*/
{
KeyType key; /*关键字项*/
InfoType data; /*其他数据项,类型为InfoType*/
} RecType;
void InsertSort(RecType R[],int n) /*对R[0..n-1]按递增有序进行直接插入排序*/
{
int i,j,k;
RecType temp;
for (i=1;in;i++)
{
temp=R[i];
j=i-1; /*从右向左在有序区R[0..i-1]中找R[i]的插入位置*/
while (j=0 temp.keyR[j].key)
{
R[j+1]=R[j]; /*将关键字大于R[i].key的记录后移*/
j--;
}
R[j+1]=temp; /*在j+1处插入R[i]*/
printf( i=%d ,i); /*输出每一趟的排序结果*/
for (k=0;kn;k++)
printf(%3d,R[k].key);
printf(\n);
}
}
void main()
{
int i,k,n=10;
KeyType a[]={9,8,7,6,5,4,3,2,1,0};
RecType R[MAXE];
for (i=0;in;i++)
R[i].key=a[i];
printf(\n);
printf( 初始关键字 ); /*输出初始关键字序列*/
for (k=0;kn;k++)
printf(%3d,R[k].key);
printf(\n);
InsertSort(R,n);
printf( 最后结果 ); /*输出初始关键字序列*/
for (k=0;kn;k++)
printf(%3d,R[k].key);
printf(\n\n);
}
[实验2] 快速排序算法的应用
实验内容与要求:
编写一个程序,实现对某一张顺序表的快速排序算法。
分析:
快速排序算法每次任取一个记录的关键字为标准,将其余记录分为两组,将所有关键字小于或等于标准的记录都放在它的位置之前,将所有关键字大于标准的记录都放在它的位置之后。对这两组再进行快速排序,直到完全有序。每递归1次,递归深度加1。
参考程序:
#includestdio.h
typedef int node;
node afile[20];
node x;
int d,dl,n;
int l,r,i,j;
void q(int l,int r){
??? int p;
??? d++;
??? if(dld)
?????? dl=d;
??? printf(dl=%d???? ,dl);
??? printf(d=%d\n,d);
??? if(lr){
?????? i=l; j=r;
?????? x=afile[i];
?????? while(i!=j){
?????????? while((afile[j]x)(ji))
????????????? j--;
??????????? if(ij)
????????????? afile[i++]=afile[j];
?????????? while((afile[i]x)(ji))
????????????? i++;
?????????? if(ij)
????????????? afile[j--]=afile[i];
?????? ? }
?????? af
文档评论(0)