- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
排序定义——将一个数据元素(或记录)的任意序列,重新排列成一个按关键字有序的序列叫~
排序分类
按待排序记录所在位置
内部排序:待排序记录存放在内存
外部排序:排序过程中需对外存进行访问的排序
按排序依据原则
插入排序:直接插入排序、折半插入排序、希尔排序
交换排序:冒泡排序、快速排序
选择排序:简单选择排序、堆排序
归并排序:2-路归并排序
基数排序
按排序所需工作量
简单的排序方法:T(n)=O(n²)
先进的排序方法:T(n)=O(logn)
基数排序:T(n)=O(d.n)
排序基本操作
比较两个关键字大小
将记录从一个位置移动到另一个位置
8.1 插入排序
直接插入排序
排序过程:整个排序过程为n-1趟插入,即先将序列中第1个记录看成是一个有序子序列,然后从第2个记录开始,逐个进行插入,直至整个序列有序
算法描述
例
49 38 65 97 76 13 27
i=2 38 (38 49) 65 97 76 13 27
i=3 65 (38 49 65) 97 76 13 27
i=4 97 (38 49 65 97) 76 13 27
i=5 76 (38 49 65 76 97) 13 27
i=6 13 (13 38 49 65 76 97) 27
i=1 ( )
i=7 (13 38 49 65 76 97) 27
27
97
76
65
49
38
27
算法评价
时间复杂度
若待排序记录按关键字从小到大排列(正序)
关键字比较次数:
记录移动次数:
若待排序记录按关键字从大到小排列(逆序)
关键字比较次数:
记录移动次数:
若待排序记录是随机的,取平均值
关键字比较次数:
记录移动次数:
T(n)=O(n²)
空间复杂度:S(n)=O(1)
Ch8_1.c
折半插入排序
排序过程:用折半查找方法确定插入位置的排序叫~
例
i=1 (30) 13 70 85 39 42 6 20
i=2 13 (13 30) 70 85 39 42 6 20
i=7 6 (6 13 30 39 42 70 85 ) 20
…...
i=8 20 (6 13 20 30 39 42 70 85 )
算法描述
算法评价
时间复杂度:T(n)=O(n²)
空间复杂度:S(n)=O(1)
Ch8_2.c
希尔排序(缩小增量法)
排序过程:先取一个正整数d1n,把所有相隔d1的记录放一组,组内进行直接插入排序;然后取d2d1,重复上述分组和排序操作;直至di=1,即所有记录放进一个组中排序为止
算法描述
Ch8_3.c
#define T 3
int d[]={5,3,1};
49
13
38
27
27
4
55
38
65
48
97
55
76
4
希尔排序特点
子序列的构成不是简单的“逐段分割”,而是将相隔某个增量的记录组成一个子序列
希尔排序可提高排序速度,因为
分组后n值减小,n²更小,而T(n)=O(n²),所以T(n)从总体上看是减小了
关键字较小的记录跳跃式前移,在进行最后一趟增量为1的插入排序时,序列已基本有序
增量序列取法
无除1以外的公因子
最后一个增量值必须为1
8.2 交换排序
冒泡排序
排序过程
将第一个记录的关键字与第二个记录的关键字进行比较,若为逆序r[1].keyr[2].key,则交换;然后比较第二个记录与第三个记录;依次类推,直至第n-1个记录和第n个记录比较为止——第一趟冒泡排序,结果关键字最大的记录被安置在最后一个记录上
对前n-1个记录进行第二趟冒泡排序,结果使关键字次大的记录被安置在第n-1个记录位置
重复上述过程,直到“在一趟排序过程中没有进行过交换记录的操作”为止
例
38
49
76
97
13
97
27
97
30
97
13
76
76
76
27
30
13
65
27
65
30
65
13
13
49
49
30
49
27
38
27
38
30
38
算法描述
算法评价
时间复杂度
最好情况(正序)
比较次数:n-1
移动次数:0
最坏情况(逆序)
比较次数:
移动次数:
空间复杂度:S(n)=O(1)
T(n)=O(n²)
Ch8_4.c
快速排序
基本思想:通过一趟
文档评论(0)