- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
排序算法思
第9章 排序;第9章 排序;按排序所需工作量
简单的排序方法:T(n)=O(n2)
先进的排序方法:T(n)=O(logn)
*基数排序:T(n)=O(d.n)
排序基本操作
比较两个关键字大小
将记录从一个位置移动到另一个位置; 当待排序记录的关键字均不相同时,排序结果是惟一的,否则排序结果不唯一。
在待排序的文件中,若存在多个关键字相同的记录,经过排序后这些具有相同关键字的记录之间的相对次序保持不变,该排序方法是稳定的;若具有相同关键字的记录之间的相对次序发生变化,则称这种排序方法是不稳定的。
注意:
排序算法的稳定性是针对所有输入实例而言的。即在所有可能的输入实例中,只要有一个实例使得算法不满足稳定性要求,则该排序算法就是不稳定的。;9.1 插入排序;例;void InsertSort(SqList L) { // 算法10.1
// 对顺序表L作直接插入排序。
for (i=2; i=L.length; ++i)
if (LT(L.r[i].key, L.r[i-1].key)) {
// 时,需将L.r[i]插入有序子表
L.r[0] = L.r[i]; // 复制为哨兵
for (j=i-1; LT(L.r[0].key, L.r[j].key); --j)
L.r[j+1] = L.r[j]; // 记录后移
L.r[j+1] = L.r[0]; // 插入到正确位置
}
} // InsertSort;算法评价
时间复杂度
若待排序记录按关键字从小到大排列(正序)
关键字比较次数:;折半插入排序
排序过程:用折半查找方法确定插入位置的排序叫~;算法描述 算法10.2 P267
void BInsertSort(SqList L) {// 对顺序表L作折半插入排序。
for (i=2; i=L.length; ++i) {
L.r[0] = L.r[i]; // 将L.r[i]暂存到L.r[0]
low = 1; high = i-1;
while (low=high) {// 在r[low..high]中折半查找有序插入的位置
m = (low+high)/2; // 折半
if (LT(L.r[0].key, L.r[m].key)) high = m-1; // 插入点在低半区
else low = m+1; // 插入点在高半区
}
for (j=i-1; j=high+1; --j) L.r[j+1] = L.r[j]; // 记录后移
L.r[high+1] = L.r[0]; // 插入
}
} // BInsertSort;*希尔排序(缩小增量法)
排序过程:先取一个正整数d1n,把所有相隔d1的记录放一组,组内进行直接插入排序;然后取d2d1,重复上述分组和排序操作;直至di=1,即所有记录放进一个组中排序为止;取d3=1
三趟分组:;算法描述 算法10.5 P272;希尔排序特点
子序列的构成不是简单的“逐段分割”,而是将相隔某个增量的记录组成一个子序列
希尔排序可提高排序速度,因为
分组后n值减小,n2更小,而T(n)=O(n2),所以T(n)从总体上看是减小了
关键字较小的记录跳跃式前移,在进行最后一趟增量为1的插入排序时,序列已基本有序
增量序列取法
无除1以外的公因子
最后一个增量值必须为1;9.2 交换排序;例;算法描述 C语言;快速排序
基本思想:通过一趟排序,将待排序记录分割成独立的两部分,其中一部分记录的关键字均比另一部分记录的关键字小,则可分别对这两部分记录进行排序,以达到整个序列有序
排序过程:对r[s……t]中记录进行一趟快速排序,附设两个指针i和j,设枢轴记录rp=r[s],x=rp.key
T. Hoare partition
初始时令i=s,j=t
首先从j所指位置向前搜索第一个关键字小于x的记录,并和rp交换
再从i所指位置起向后搜索,找到第一个关键字大于x的记录,和rp交换
重复上述两步,直至i==j为止
再分别对两个子序列进行快速排序,直到每个子序列只含有一个记录为止;例;int Partition(SqList L, int low, int high) { // 算法10.6(
您可能关注的文档
最近下载
- 临床医学 《门静脉高压症》教学课件.ppt VIP
- 最新:机械通气患者转运课件.pptx VIP
- 最新清晰版ISO50001(中word版).docx VIP
- (高清版)DB44∕T 2598-2024 《省级体育社会团体建设规范》.pdf VIP
- 现浇钢筋混凝土楼板施工工艺.pdf VIP
- 装修贷款业务培训.pptx VIP
- 建筑施工岗位安全风险告知卡(完整共十张).pdf VIP
- 最新清晰版ISO50001(中文PDF版).pdf VIP
- 磁性材料分类与应用.ppt VIP
- Unit 2 Learning English is fun! 单元拔尖检测(含答案及听力音频)冀教版英语七年级上册.doc VIP
文档评论(0)