- 1、本文档共26页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
[工学]数据结构第23讲_插入排序2和交换排序_C
3)具体做法 首先将静态链表中数组下标为“1” 的分量(结点)和表头结点构成一个循环链表,然后依次将下标为“2”至“n”的分量(结点)按记录关键字非递减有序插入到循环链表中。 4)表插入排序性能分析 从表插入排序的过程可见,表插入排序的基本操作仍是将一个记录插入到已排好序的有序表当中。和直接插排序相比,不同之处仅是以修改2n次指针值代替移动记录,排序过程中所需进行的关键字间的比较次数相同。因此表插入排序的时间复杂度仍是O(n2)。 4)表插入排序性能分析 表插入排序的结果只是求得一个有序链表,则只能对它进行顺序查找,不能进行随机查找,为了能实现有序表的折半查找,尚需对记录进行重新排列。 * * * * * 10.2 插入排序 直接插入排序 折半插入排序 2-路插入排序 表插入排序 希尔排序 4.表插入排序 1)基本思想 通过改变排序过程中采用的存储结构,减少在排序过程中进行“移动”记录的操作。利用静态链表进行排序,并在排序完成之后,一次性地调整各个记录相互之间的位置,即将每个记录都调整到它们所应该在的位置上。 #define MAXSIZE 100 //静态链表容量 Typedef struct{ RcdType rc; //记录项 int next; //指针项 } SLNode; //表结点类型 Typedef struct{ SLNode r[MAXSIZE+1]; //0号单元为表头结点 int length; //链表当前长度 } SLinkListType; //静态链表类型 2)待排记录序列的存储结构 - - - - - - - 0 1 49 27 13 76 97 65 38 49 MAXINT 8 7 6 5 4 3 2 1 0 初始 状态 - - - - - - 1 0 2 49 27 13 76 97 65 38 49 MAXINT 8 7 6 5 4 3 2 1 0 i=3 key域 next域 - - - - - - - 0 1 49 27 13 76 97 65 38 49 MAXINT 8 7 6 5 4 3 2 1 0 i=2 38 1 2 3 65 0 - - - - - 0 1 3 2 49 27 13 76 97 65 38 49 MAXINT 8 7 6 5 4 3 2 1 0 i=4 97 4 0 - - - - 0 4 1 3 2 49 27 13 76 97 65 38 49 MAXINT 8 7 6 5 4 3 2 1 0 i=5 - - - 4 0 5 1 3 2 49 27 13 76 97 65 38 49 MAXINT 8 7 6 5 4 3 2 1 0 i=6 - - 2 4 0 5 1 3 6 49 27 13 76 97 65 38 49 MAXINT 8 7 6 5 4 3 2 1 0 i=7 - 2 7 4 0 5 1 3 6 49 27 13 76 97 65 38 49 MAXINT 8 7 6 5 4 3 2 1 0 i=8 76 4 5 13 6 2 27 7 2 49 3 8 5.希尔排序 1)基本思想 又称为“缩小增量排序” 。先将整个待排元素序列分割成若干个子序列(由相隔某个“增量”的元素组成的)分别进行直接插入排序,待整个序列中的元素基本有序(增量足够小)时,再对全体元素进行一次直接插入排序(接近最好情况,效率很高),因此希尔排序在时间效率上比前两种方法有较大提高。 65 1 13 25 25 97 49 6 5 4 3 2 3 25 1 97 49 65 13 25 6 5 4 3 2 2 13 1 97 49 65 25 25 6 5 4 3 2 1 13 1 97 65 49 25 25 6 5 4 3 2 增量 3 增量 2 增量 1 希 尔 排 序 过 程 void ShellInsert ( SqList L, int dk ) { //一趟希尔插入排序。本算法对直接插入算法作了以下修改: //1.前后记录位置的增量是dk,而不是1; //2.L.r[0]只是暂存单元,不是哨兵。当j=0时,插入位置已找到 for ( i=dk+1; i=L.length; ++i ) if ( L.r[i].key L.r[i-dk].key) {//将R[i]插入有序增量子表 L.r[0] = L.r[i]; // 暂存在R[0] for (j=i-dk; j0 (L.r[0].key L.r[j].key);j -= dk) L.r[j+dk]
您可能关注的文档
最近下载
- 人教版六年级上册英语第三单元教案和反思1.pdf
- ISO 20653-2023中文-道路车辆.防护等级.pdf
- 幼儿园教案幼儿园中班优质课教案.doc VIP
- 2023中国工商银行四川分行秋季校园招聘笔试历年典型考题及考点剖析附带答案详解.docx
- 顺丰控股香港上市IPO招股说明书2024版.pdf
- 3.3 地波天线.ppt
- 中国第一高中湖北卷湖北省武汉市华中师范大学第一附属中2024-2025学年高三上学期10月检测(10.19-10(含答案).pdf VIP
- 智慧消防及消防监管云平台解决方案.pptx
- 美国Megger TM1700断路器分析仪使用说明书.pdf VIP
- 水利科学技术史.pdf VIP
文档评论(0)