- 3
- 0
- 约5.16千字
- 约 26页
- 2018-03-10 发布于浙江
- 举报
[工学]数据结构第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]
您可能关注的文档
最近下载
- 一种连续性混杂型废塑料无害化热解处置系统及处置方法.pdf VIP
- 糖画介绍课件.pptx VIP
- 湘教版八年级地理下册6.1《 东北地区的地理位置与自然环境》优质教案.docx
- 变态心理学(新教材).pdf VIP
- 农村饮水安全项目社会稳定风险评估与风险防控技术研究报告.docx
- 高三数学三角函数一轮复习.doc VIP
- 施工现场管理机构设置及职责.docx VIP
- 全真派道士申请书.docx VIP
- Panasonic松下 洗衣机 XQG100-V198,XQG100-V19M,XQG100-V19S,XQG100-L186,XQG100-L187,XQG100-L18M,XQG100-L188,XQG100-L18R,XQG100-L18S,XQG100-L1KR,XQG100-3X0R,XQG100-L18T 用户手册.pdf
- 心理健康热线接听操作指南.docx VIP
原创力文档

文档评论(0)