数据结构(C++版)第8章 排序技术

合集下载

(完整word版)数据结构 第八章排序

(完整word版)数据结构 第八章排序

第八章排序:习题习题一、选择题1.在所有排序方法中,关键字比较的次数与记录的初始排列次序无关的是( )。

A.希尔排序B.冒泡排序C.插入排序D.选择排序2.设有1000个无序的记录,希望用最快的速度挑选出其中前10个最大的记录,最好选用( )排序法。

A.冒泡排序B.快速排序C.堆排序D.基数排序3.在待排序的记录序列基本有序的前提下,效率最高的排序方法是( )。

A.插入排序B.选择排序C.快速排序D.归并排序’4.不稳定的排序方法是指在排序中,关键字值相等的不同记录的前后相对位置( )。

A.保持不变B.保持相反C.不定D.无关5.内部排序是指在排序的整个过程中,全部数据都在计算机的( )中完成的排序。

A. 内存储器B.外存储器C.内存储器和外存储器D.寄存器6.用冒泡排序的方法对n个数据进行排序,第一趟共比较( )对记录。

A.1B.2C.n-lD.n7.直接插入排序的方法是从第( )个记录开始,插入前边适当位置的排序方法。

A.1B.2C.3D.n8.用堆排序的方法对n个数据进行排序,首先将n个记录分成( )组。

A.1B.2C.n-lD.n9.归并排序的方法对n个数据进行排序,首先将n个记录分成( )组,两两归并。

A.1B.2C.n-lD.n10.直接插入排序的方法要求被排序的数据( )存储。

A.必须是顺序B.必须是链表C.顺序或链表D.二叉树11.冒泡排序的方法要求被排序的数据( )存储。

A.必须是顺序B.必须是链表C.顺序或链表D.二叉树12.快速排序的方法要求被排序的数据( )存储。

A.必须是顺序B.必须是链表C.顺序或链表D.二叉树13.排序方法中,从未排序序列中依次取出记录与已排序序列(初始时为空)中的记录进行比较,将其放入已排序序列的正确位置上的方法,称为( )。

A.希尔排序B.冒泡排序C.插入排序D.选择排序14.每次把待排序的记录划分为左、右两个子序列,其中左序列中记录的关键字均小于等于基准记录的关键字,右序列中记录的关键字均大于基准记录的关键字,则此排序方法叫做( )。

《数据结构(C语言版 第2版)》(严蔚敏 著)第八章练习题答案

《数据结构(C语言版 第2版)》(严蔚敏 著)第八章练习题答案

《数据结构(C语言版第2版)》(严蔚敏著)第八章练习题答案第8章排序1.选择题(1)从未排序序列中依次取出元素与已排序序列中的元素进行比较,将其放入已排序序列的正确位置上的方法,这种排序方法称为()。

A.归并排序B.冒泡排序C.插入排序D.选择排序答案:C(2)从未排序序列中挑选元素,并将其依次放入已排序序列(初始时为空)的一端的方法,称为()。

A.归并排序B.冒泡排序C.插入排序D.选择排序答案:D(3)对n个不同的关键字由小到大进行冒泡排序,在下列()情况下比较的次数最多。

A.从小到大排列好的B.从大到小排列好的C.元素无序D.元素基本有序答案:B解释:对关键字进行冒泡排序,关键字逆序时比较次数最多。

(4)对n个不同的排序码进行冒泡排序,在元素无序的情况下比较的次数最多为()。

A.n+1B.n C.n-1D.n(n-1)/2答案:D解释:比较次数最多时,第一次比较n-1次,第二次比较n-2次……最后一次比较1次,即(n-1)+(n-2)+…+1=n(n-1)/2。

(5)快速排序在下列()情况下最易发挥其长处。

A.被排序的数据中含有多个相同排序码B.被排序的数据已基本有序C.被排序的数据完全无序D.被排序的数据中的最大值和最小值相差悬殊答案:C解释:B选项是快速排序的最坏情况。

(6)对n个关键字作快速排序,在最坏情况下,算法的时间复杂度是()。

A.O(n)B.O(n2)C.O(nlog2n)D.O(n3)答案:B解释:快速排序的平均时间复杂度为O(nlog2n),但在最坏情况下,即关键字基本排好序的情况下,时间复杂度为O(n2)。

(7)若一组记录的排序码为(46,79,56,38,40,84),则利用快速排序的方法,以第一个记录为基准得到的一次划分结果为()。

A.38,40,46,56,79,84B.40,38,46,79,56,84C.40,38,46,56,79,84D.40,38,46,84,56,79答案:C(8)下列关键字序列中,()是堆。

C语言八大排序算法

C语言八大排序算法

C语⾔⼋⼤排序算法C语⾔⼋⼤排序算法,附动图和详细代码解释!来源:C语⾔与程序设计、⽵⾬听闲等⼀前⾔如果说各种编程语⾔是程序员的招式,那么数据结构和算法就相当于程序员的内功。

想写出精炼、优秀的代码,不通过不断的锤炼,是很难做到的。

⼆⼋⼤排序算法排序算法作为数据结构的重要部分,系统地学习⼀下是很有必要的。

1、排序的概念排序是计算机内经常进⾏的⼀种操作,其⽬的是将⼀组“⽆序”的记录序列调整为“有序”的记录序列。

排序分为内部排序和外部排序。

若整个排序过程不需要访问外存便能完成,则称此类排序问题为内部排序。

反之,若参加排序的记录数量很⼤,整个序列的排序过程不可能在内存中完成,则称此类排序问题为外部排序。

2、排序分类⼋⼤排序算法均属于内部排序。

如果按照策略来分类,⼤致可分为:交换排序、插⼊排序、选择排序、归并排序和基数排序。

如下图所⽰:3、算法分析1.插⼊排序*直接插⼊排序*希尔排序2.选择排序*简单选择排序*堆排序3.交换排序*冒泡排序*快速排序4.归并排序5.基数排序不稳定排序:简单选择排序,快速排序,希尔排序,堆排序稳定排序:冒泡排序,直接插⼊排序,归并排序,奇数排序1、插⼊排序将第⼀个和第⼆个元素排好序,然后将第3个元素插⼊到已经排好序的元素中,依次类推(插⼊排序最好的情况就是数组已经有序了)因为插⼊排序每次只能操作⼀个元素,效率低。

元素个数N,取奇数k=N/2,将下标差值为k的数分为⼀组(⼀组元素个数看总元素个数决定),在组内构成有序序列,再取k=k/2,将下标差值为k的数分为⼀组,构成有序序列,直到k=1,然后再进⾏直接插⼊排序。

3、简单选择排序选出最⼩的数和第⼀个数交换,再在剩余的数中⼜选择最⼩的和第⼆个数交换,依次类推4、堆排序以升序排序为例,利⽤⼩根堆的性质(堆顶元素最⼩)不断输出最⼩元素,直到堆中没有元素1.构建⼩根堆2.输出堆顶元素3.将堆低元素放⼀个到堆顶,再重新构造成⼩根堆,再输出堆顶元素,以此类推5、冒泡排序改进1:如果某次冒泡不存在数据交换,则说明已经排序好了,可以直接退出排序改进2:头尾进⾏冒泡,每次把最⼤的沉底,最⼩的浮上去,两边往中间靠16、快速排序选择⼀个基准元素,⽐基准元素⼩的放基准元素的前⾯,⽐基准元素⼤的放基准元素的后⾯,这种动作叫分区,每次分区都把⼀个数列分成了两部分,每次分区都使得⼀个数字有序,然后将基准元素前⾯部分和后⾯部分继续分区,⼀直分区直到分区的区间中只有⼀个元素的时候,⼀个元素的序列肯定是有序的嘛,所以最后⼀个升序的序列就完成啦。

《数据结构排序》课件

《数据结构排序》课件

根据实际需求选择时间复杂度和空间 复杂度最优的排序算法,例如快速排 序在平均情况下具有较好的性能,但 最坏情况下其时间复杂度为O(n^2)。
排序算法的适用场景问题
适用场景考虑因素
选择排序算法时需要考虑实际应 用场景的特点,如数据量大小、 数据类型、是否需要稳定排序等 因素。
不同场景适用不同
算法
例如,对于小规模数据,插入排 序可能更合适;对于大规模数据 ,快速排序或归并排序可能更优 。
排序的算法复杂度
时间复杂度
衡量排序算法执行时间随数据量增长而增长的速率。时间复杂度越低,算法效 率越高。常见的时间复杂度有O(n^2)、O(nlogn)、O(n)等。
空间复杂度
衡量排序算法所需额外空间的大小。空间复杂度越低,算法所需额外空间越少 。常见的空间复杂度有O(1)、O(logn)、O(n)等。
在数据库查询中,经常需要对结果进行排序,以便用户能够快速找到所需信息。排序算 法的效率直接影响到查询的响应时间。
索引与排序
数据库索引能够提高查询效率,但同时也需要考虑到排序的需求。合理地设计索引结构 ,可以加速排序操作。
搜索引擎中的排序
相关性排序
搜索引擎的核心功能是根据用户输入的 关键词,返回最相关的网页。排序算法 需要综合考虑网页内容、关键词密度、 链接关系等因素。
VS
广告与排序
搜索引擎中的广告通常会根据关键词的竞 价和相关性进行排序,以达到最佳的广告 效果。
程序中的排序应用
数组排序
在程序中处理数组时,经常需要对其进行排 序。不同的排序算法适用于不同类型的数据 和场景,如快速排序、归并排序等。
数据可视化中的排序
在数据可视化中,需要对数据进行排序以生 成图表。例如,柱状图、饼图等都需要对数 据进行排序处理。

数据结构(c言版)课件_第八章_排序_(严蔚敏、吴伟民编_清华大学出版社)

数据结构(c言版)课件_第八章_排序_(严蔚敏、吴伟民编_清华大学出版社)

算法描述
算法评价
时间复杂度
记录移动次数
最好情况:0
最坏情况:3(n-1)
比较次数: n1 (n i) 1 (n2 n)
i 1
2
T(n)=O(n²)
空间复杂度:S(n)=O(1)
Ch8_6.c
堆排序
堆的定义:n个元素的序列(k1,k2,……kn),当且仅当 满足下列关系时,称之为堆
增量序列取法 无除1以外的公因子 最后一个增量值必须为1
8.2 交换排序
冒泡排序
排序过程
将第一个记录的关键字与第二个记录的关键字进行比较,若 为逆序r[1].key>r[2].key,则交换;然后比较第二个记录与第 三个记录;依次类推,直至第n-1个记录和第n个记录比较为 止——第一趟冒泡排序,结果关键字最大的记录被安置在最 后一个记录上
二趟排序:13 4 48 38 27 49 55 65 97 76
Ch8_3.c
希尔排序特点
子序列的构成不是简单的“逐段分割”,而是将相隔某个增 量的记录组成一个子序列
希尔排序可提高排序速度,因为 分组后n值减小,n²更小,而T(n)=O(n²),所以T(n)从总体 上看是减小了
关键字较小的记录跳跃式前移,在进行最后一趟增量为1 的插入排序时,序列已基本有序
9776
7163
6257 13
4390 27
3308
38
9173 76
7267 13
6350 27
49 30
49
927 13
7360 27
65 30
65
9370 76
2977 30 76
3初0 9第7 第 第 第 第 第 始一二三四五六 关趟趟趟趟趟趟 键 字

数据结构排序PPT课件

数据结构排序PPT课件
—— 若待排序记录一部分在内存,一部分在外存, 则称为外部排序。
注:外部排序时,要将数据分批调入内存来 排序,中间结果还要及时放入外存,显然外 部排序要复杂得多。
在整堂课的教学中,刘教师总是让学 生带着 问题来 学习, 而问题 的设置 具有一 定的梯 度,由 浅入深 ,所提 出的问 题也很 明确
5.待排序记录在内存中怎样存储和处理?
在整堂课的教学中,刘教师总是让学 生带着 问题来 学习, 而问题 的设置 具有一 定的梯 度,由 浅入深 ,所提 出的问 题也很 明确
Void BInsertSort (SqList &L) // 折半插入排序
{ for ( i=2;i<=L.length;++i )
{ L.r[0] = L.r[ i ]; // 将L.r [i] 暂存到L.r[0]
处理方式: ① 顺序排序 —— 数据间的逻辑顺序关系通过其物理
存储位置的相邻来体现,排序时直接移动记录; 适合数据较少的情况!
② 链表排序 ——数据间的逻辑顺序关系通过结点中 的指针体现,排序时只修改指针,不移动数据;
③ 地址排序 —— 数据存储在一段连续地址的空间, 构造一个辅助表保持各数据的存放地址(指针),排 序时先修改辅助表中的地址,最后再移动记录。
在整堂课的教学中,刘教师总是让学 生带着 问题来 学习, 而问题 的设置 具有一 定的梯 度,由 浅入深 ,所提 出的问 题也很 明确
4. 什么叫内部排序?什么叫外部排序? —— 若待排序记录都在内存中,称为内部排序;
内部排序基本操作有两种: ◆ 比较两个关键字的大小;(比不可少的操作) ◆ 存储位置的移动。
i=8
0
1
2
3
4

数据结构(c语言版)

目录第1章绪论第2章线性表第3章栈和队列第4章串第5章数组第6章树第7章图第8章查找第9章排序第10章文件第1章绪论1.1数据结构的基本概念和术语1.2算法描述与分析1.3实习:常用算法实现及分析习题11.1数据结构的基本概念和术语1.1.1引例首先分析学籍档案类问题。

设一个班级有50个学生,这个班级的学籍表如表1.1所示。

表1.1学籍表序号学号姓名性别英语数学物理0120030301李明男8691800220030302马琳男7683855020030350刘薇薇女889390个记录又由750我们可以把表中每个学生的信息看成一个记录,表中的每个数据项组成。

该学籍表由个记录组成,记录之间是一种顺序关系。

这种表通常称为线性表,数据之间的逻辑结构称为线性结构,其主要操作有检索、查找、插入或删除等。

又如,对于学院的行政机构,可以把该学院的名称看成树根,把下设的若干个系看成它的树枝中间结点,把每个系分出的若干专业方向看成树叶,这样就形成一个树型结构,如图1.1所示。

树中的每个结点可以包含较多的信息,结点之间的关系不再是顺序的,而是分层、分叉的结构。

树型结构的主要操作有遍历、查找、插入或删除等。

最后分析交通问题。

如果把若干个城镇看成若干个顶点,再把城镇之间的道路看成边,它们可以构成一个网状的图(如图1.2所示),这种关系称为图型结构或网状结构。

在实际应用中,假设某地区有5个城镇,有一调查小组要对该地区每个城镇进行调查研究,并且每个城镇仅能调查一次,试问调查路线怎样设计才能以最高的效率完成此项工作?这是一个图论方面的问题。

交通图的存储和管理确实不属于单纯的数值计算问题,而是一种非数值的信息处理问题。

图1.2交通示意图1.1.2数据结构有关概念及术语一般来说,数据结构研究的是一类普通数据的表示及其相1968 D.E.Knuth 教授开创了数据结“数据结构”是计算机专业的一门专业基础课。

它为操作关的运算操作。

数据结构是一门主要研究怎样合理地组织数据,建立合适的数据结构,提高计算机执行程序所用的时间效率和空间效率的学科。

数据结构(C语言版)考研复习题

数据结构(C语言版)考研复习题第1 页共19 页第一章绪论1.1 简述下列概念:数据、数据元素、数据类型、数据结构、逻辑结构、存储结构、线性结构、非线性结构。

1.2 常用的存储表示方法有哪几种?1.3 算法的时间复杂度仅与问题的规模相关吗?1.4 有时为了比较两个同数量级算法的优劣,须突出主项的常数因子,而将低次项用大"O"记号表示。

例如,设T1(n)=1.39nlgn+100n+256=1.39nlgn+O(n), T2(n)=2.0nlgn-2n=2.0lgn+O(n), 这两个式子表示,当n足够大时T1(n)优于T2(n),因为前者的常数因子小于后者。

请用此方法表示下列函数,并指出当n足够大时,哪一个较优,哪一个较劣?函数大"O"表示优劣(1) T1(n)=5n22-3n+60lgn 5n22+O(n)(2) T2(n)=3n22+1000n+3lgn 3n22+O(n)(3) T3(n)=8n22+3lgn 8n22+O(lgn)(4) T4(n)=1.5n2+6000nlgn 1.5n2+O(nlgn)第二章线性表2.1 试描述头指针、头结点、开始结点的区别、并说明头指针和头结点的作用。

2.2 何时选用顺序表、何时选用链表作为线性表的存储结构为宜?2.3 为什么在单循环链表中设置尾指针比设置头指针更好?2.4 下述算法的功能是什么?LinkList Demo(LinkList L){ // L 是无头结点单链表ListNode *Q,*P;if(L&&L->next){Q=L;L=L->next;P=L;while (P->next) P=P->next;P->next=Q; Q->next=NULL;}return L;}// Demo2.5设线性表的n个结点定义为(a0,a1,...a n-1),重写顺序表上实现的插入和删除算法:InsertList 和DeleteList.2.6 设顺序表L是一个递减有序表,试写一算法,将x插入其后仍保持L的有序性。

数据结构与算法第8章答案

第8 章排序技术课后习题讲解1. 填空题⑴排序的主要目的是为了以后对已排序的数据元素进行()。

【解答】查找【分析】对已排序的记录序列进行查找通常能提高查找效率。

⑵对n个元素进行起泡排序,在()情况下比较的次数最少,其比较次数为()。

在()情况下比较次数最多,其比较次数为()。

【解答】正序,n-1,反序,n(n-1)/2⑶对一组记录(54, 38, 96, 23, 15, 72, 60, 45, 83)进行直接插入排序,当把第7个记录60插入到有序表时,为寻找插入位置需比较()次。

【解答】3【分析】当把第7个记录60插入到有序表时,该有序表中有2个记录大于60。

⑷对一组记录(54, 38, 96, 23, 15, 72, 60, 45, 83)进行快速排序,在递归调用中使用的栈所能达到的最大深度为()。

【解答】3⑸对n个待排序记录序列进行快速排序,所需要的最好时间是(),最坏时间是()。

【解答】O(nlog2n),O(n2)⑹利用简单选择排序对n个记录进行排序,最坏情况下,记录交换的次数为()。

【解答】n-1⑺如果要将序列(50,16,23,68,94,70,73)建成堆,只需把16与()交换。

【解答】50⑻对于键值序列(12,13,11,18,60,15,7,18,25,100),用筛选法建堆,必须从键值为()的结点开始。

【解答】60【分析】60是该键值序列对应的完全二叉树中最后一个分支结点。

2. 选择题⑴下述排序方法中,比较次数与待排序记录的初始状态无关的是()。

A插入排序和快速排序B归并排序和快速排序C选择排序和归并排序D插入排序和归并排序【解答】C【分析】选择排序在最好、最坏、平均情况下的时间性能均为O(n2),归并排序在最好、最坏、平均情况下的时间性能均为O(nlog2n)。

⑵下列序列中,()是执行第一趟快速排序的结果。

A [da,ax,eb,de,bb] ff [ha,gc]B [cd,eb,ax,da] ff [ha,gc,bb]C [gc,ax,eb,cd,bb] ff [da,ha]D [ax,bb,cd,da] ff [eb,gc,ha]【解答】A【分析】此题需要按字典序比较,前半区间中的所有元素都应小于ff,后半区间中的所有元素都应大于ff。

数据结构C语言版(第2版)严蔚敏人民邮电出版社课后习题答案

数据结构( C语言版)(第 2版)课后习题答案李冬梅2015.3目录第 1 章绪论 (1)第 2 章线性表 (5)第 3 章栈和队列 (13)第 4 章串、数组和广义表 (26)第 5 章树和二叉树 (33)第 6 章图 (43)第 7 章查找 (54)第 8 章排序 (65)第1章绪论1.简述下列概念:数据、数据元素、数据项、数据对象、数据结构、逻辑结构、存储结构、抽象数据类型。

答案:数据:是客观事物的符号表示,指所有能输入到计算机中并被计算机程序处理的符号的总称。

如数学计算中用到的整数和实数,文本编辑所用到的字符串,多媒体程序处理的图形、图像、声音、动画等通过特殊编码定义后的数据。

数据元素:是数据的基本单位,在计算机中通常作为一个整体进行考虑和处理。

在有些情况下,数据元素也称为元素、结点、记录等。

数据元素用于完整地描述一个对象,如一个学生记录,树中棋盘的一个格局(状态)、图中的一个顶点等。

数据项:是组成数据元素的、有独立含义的、不可分割的最小单位。

例如,学生基本信息表中的学号、姓名、性别等都是数据项。

数据对象:是性质相同的数据元素的集合,是数据的一个子集。

例如:整数数据对象是集合N={0 ,± 1,± 2,, } ,字母字符数据对象是集合C={‘A’,‘B’, , ,‘Z’,‘ a’,‘ b’, , ,‘z ’} ,学生基本信息表也可是一个数据对象。

数据结构:是相互之间存在一种或多种特定关系的数据元素的集合。

换句话说,数据结构是带“结构”的数据元素的集合,“结构”就是指数据元素之间存在的关系。

逻辑结构:从逻辑关系上描述数据,它与数据的存储无关,是独立于计算机的。

因此,数据的逻辑结构可以看作是从具体问题抽象出来的数学模型。

存储结构:数据对象在计算机中的存储表示,也称为物理结构。

抽象数据类型:由用户定义的,表示应用问题的数学模型,以及定义在这个模型上的一组操作的总称。

具体包括三部分:数据对象、数据对象上关系的集合和对数据对象的基本操作的集合。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
25* 25* 21
16 16
16 16 25*
25 25
25 25 25
d=2
13
08
d=1
08 08
49
49
关键问题(1)应如何分割待排序记录? 解决方法:
将相隔某个“增量”的记录组成一个子序列。
增量应如何取? 希尔最早提出的方法是d1=n/2,di+1=di/2。 算法描述:
for (d=n/2; d>=1; d=d/2) { 以d为增量,进行组内直接插入排序; }
希尔插入排序过程示例
1 初始序列 40 2
25 25
3
49 49
4
25* 25*
5
16 16
6
21 21
7
08 08 49 49 40 40 30
8
30 30 30 30 30 30 40
9
13 13 40 40 49
d=4
40
13
21 21
21 21 13
08 08
13 13 16
25* 25*
关键问题(2)子序列内如何进行直接插入排序? 解决方法: 在插入记录r[i]时,自r[i-d]起往前跳跃式(跳跃幅 度为d)搜索待插入位置,并且r[0]只是暂存单元, 不是哨兵。当搜索位置<0,表示插入位置已找到。 在搜索过程中,记录后移也是跳跃d个位置。 在整个序列中,前d个记录分别是d个子序列中的 第一个记录,所以从第d+1个记录开始进行插入。
25* 25* 21
16 16
16 16 25*
25 25
25 25 25
d=2
13
08
d=1
08 08
49
49
关键问题(2)子序列内如何进行直接插入排序?(一趟 希尔排序) 算法描述:
for (i=d+1; i<=n; i++) //将r[i]插入到所属的子序列中 { r[0]=r[i]; //暂存待插入记录 j=i-d; //j指向所属子序列的最后一个记录 while (j>0 && r[0]<r[j]) { r[j+d]=r[j]; //记录后移d个位置 j=j-d; //比较同一子序列的前一个记录 } r[j+d]=r[0]; }
i=2 i=3 i=4 i=5 i=6
22
21 21 21 10 10 10
r[0]的作用? 暂存单元
10
25 18
监视哨
关键问题(1)如何构造初始的有序序列?
解决方法:
将第1个记录看成是初始有序表,然后从第2个记录起 依次插入到这个有序表中,直到将第n个记录插入。
算法描述:
for (i=2;ቤተ መጻሕፍቲ ባይዱi<=n; i++) { 插入第i个记录,即第i趟直接插入排序; }
学号 0001 0002 姓名 王 军 李 明 高数 85 64 英语 68 72 思想品德 88 92
0003 …
汤晓影 …
85 …
78 …
86 …
按学号排序——单键排序 按成绩(高数+英语+思想品德)排序——多键排序
排序的基本概念
设关键码分别为k1, k2, „, km,多键排序有两种方法: ⑴ 依次对记录进行m次排序,第一次按k1排序,第二次按k2排 序,依此类推。这种方法要求各趟排序所用的算法是稳定的; ⑵ 将关键码k1, k2, „, km分别视为字符串依次首尾连接在一起, 形成一个新的字符串,然后,对记录序列按新形成的字符串排 序。
关键问题(2)如何查找待插入记录的插入位置? 解决方法: 在i-1个记录的有序区r[1] ~ r[i-1]中插入记录r[i],首 先顺序查找r[i]的正确插入位置,然后将r[i]插入到相 应位置。
算法描述:
r[0]=r[i]; j=i-1; while (r[0]<r[j]) { r[j+1]=r[j]; j--; }
基于比较的内排序 1. 插入排序 2. 交换排序 3. 选择排序 4. 归并排序
排序算法的性能
1. 基本操作。内排序在排序过程中的基本操作: ⑴比较:关键码之间的比较; ⑵移动:记录从一个位置移动到另一个位置。 2. 辅助存储空间。 辅助存储空间是指在数据规模一定的条件下,除了存 放待排序记录占用的存储空间之外,执行算法所需要 的其他存储空间。 3.算法本身的复杂程度。
直接插入排序算法性能分析
平均情况下(随机排列):
n i+1 (n +4)(n -1) 比较次数: = 4 i=2 2 n(i + 3 ) (n +6)(n -1) = 移动次数: 4 i=2 2
时间复杂度为O(n2)。
插入排序
直接插入排序算法性能分析
空间性能:需要一个记录的辅助空间。
直接插入排序算法是一种稳定的排序算法。
4 3 5 4 3 2 1 4 5 4 3 2 3 3 5 4 3 2 2 2 5 4 1 1 1 1 5
2
最坏情况下(逆序或反序): 1 n 比较次数: i = (n +2)(n -1)
2 n (n +4)(n -1) 移动次数: i +1)= ( 2 i=2
i=2
时间复杂度为O(n2)。
插入排序
多键排序
单键排序
多关键字排序
例如: 我们可以将一副扑克牌的排序过程看成由花色和面值 两个关键字进行排序的问题。 若规定花色和面值的顺序如下: 花色: 梅花 < 方块 < 红桃 < 黑桃 面值: A<2<3<…<10<J<Q<K
并进一步规定花色的优先级高于面值, 则一副扑克牌从小到大 的顺序为:
(1)应如何分割待排序记录,才能保证整个序列逐步 向基本有序发展? (2)子序列内如何进行直接插入排序?
希尔排序
分割待排序记录的目的? 1. 减少待排序记录个数; 2. 使整个序列向基本有序发展。 基本有序:接近正序,例如{1, 2, 8, 4, 5, 6, 7, 3, 9}; 局部有序:部分有序,例如{6, 7, 8, 9, 1, 2, 3, 4, 5}。 局部有序不能提高直接插入排序算法的时间性能。 启示? 子序列的构成不能是简单地“逐段分割”,而是将相 距某个“增量”的记录组成一个子序列。
希尔插入排序过程示例
1 初始序列 40 2
25 25
3
49 49
4
25* 25*
5
16 16
6
21 21
7
08 08 49 49 40 40 30
8
30 30 30 30 30 30 40
9
13 13 40 40 49
d=4
40
13
21 21
21 21 13
08 08
13 13 16
25* 25*
“低位优先”排序法:
首先按面值从小到大把牌摆成13叠(每叠4张牌),
然后将每叠牌按面值的次序收集到一起, 再对这些牌按花色摆成4叠, 每叠有13张牌, 最后把这4叠牌按花色的次序收集到一起 是分配与收集交替进行。分配与收集的次数等于排序码的数

排序的基本概念
排序的分类 1. 内排序:在排序的整个过程中,待排序的所有记录 全部被放置在内存中
排序前 ( 56, 34, 47, 23, 66, 18, 82, 47 )
排序后 ( 18, 23, 34, 47, 47, 56, 66, 82 )
稳定
排序后 ( 18, 23, 34, 47, 47, 56, 66, 82 )
不稳定
排序的基本概念
单键排序:根据一个关键码进行的排序; 多键排序:根据多个关键码进行的排序。
希尔排序算法的时间性能
希尔排序开始时增量较大,每个子序列中的记录个数 较少,从而排序速度较快;当增量较小时,虽然每个 子序列中记录个数较多,但整个序列已基本有序,排 序速度也较快。 希尔排序算法的时间性能是所取增量的函数,而到目 前为止尚未有人求得一种最好的增量序列。 研究表明,希尔排序的时间性能在O(n2)和O(nlog2n) 之间。当n在某个特定范围内,希尔排序所需的比较 次数和记录的移动次数约为O(n1.3 ) 。
2. 外排序:由于待排序的记录个数太多,不能同时放 置在内存,而需要将一部分记录放置在内存,另一 部分记录放置在外存上,整个排序过程需要在内外 存之间多次交换数据才能得到排序的结果。
排序的基本概念
排序的分类 1. 基于比较:基本操作——关键码的比较和记录的移动, 其最差时间下限已经被证明为Ω(nlog2n)。 2. 不基于比较:根据关键码的分布特征。
梅花A, 梅花2, …,梅花K;方块A,方块2,…, 方块K; 红桃A, 红桃2, …, 红桃K; 黑桃A, 黑桃2, …, 黑桃K。
多关键字排序的两种方法
“高位优先”排序法:其中一种是先按花色分成有序的四类 (分别放入4个桶中),然后再按面值对每一类从小到大排序 (分别放入13个桶中)。
两次分配,一次收集
希尔排序
改进的着眼点: (1)若待排序记录按关键码基本有序时,直接插入 排序的效率可以大大提高; (2)由于直接插入排序算法简单,则在待排序记录 数量n较小时效率也很高。
希尔排序
基本思想:将整个待排序记录分割成若干个子序列, 在子序列内分别进行直接插入排序,待整个序列中的 记录基本有序时,对全体记录进行直接插入排序。 需解决的关键问题?
如果r[i]>=r[i-1],内层循 环会出现什么情况?
直接插入排序算法性能分析
最好情况下(正序): 比较次数:n-1 移动次数:2(n-1)
2 3 1 1 2 2 3 3 4 4 5 5
1
1 1
相关文档
最新文档