数据结构教程李春葆课后答案第10章内排序

合集下载

李春葆《数据结构教程》(第4版)笔记和课后习题详解(第8~10章)【圣才出品】

李春葆《数据结构教程》(第4版)笔记和课后习题详解(第8~10章)【圣才出品】

李春葆《数据结构教程》(第4版)笔记和课后习题详解第8章图8.1复习笔记一、图的基本概念1.图的定义图都是由顶点和边构成的。

采用形式化的定义,图G由两个集合V和E组成,记为G =(V,E),其中V是顶点的有限集合,记为V(G),E是连接V中两个不同顶点(顶点对)的边的有限集合,记为E(G)。

抽象数据类型图的定义如下:2.图的基本术语(1)端点和邻接点在一个无向图中,若存在一条边(i,j),则称顶点i和顶点j为该边的两个端点,并称它们互为邻接点,即顶点i是顶点j的一个邻接点,顶点j也是顶点i的一个邻接点。

(2)顶点的度、入度和出度①度在无向图中,某顶点所具有的边的数目称为该顶点的度。

②入度在有向图中,顶点i的度又分为入度和出度,以顶点i为终点的入边的数目,称为该顶点的入度。

③出度以顶点i为起点的出边的数目,称为该顶点的出度。

一个顶点的入度与出度的和为该顶点的度。

(3)完全图若无向图中每两个顶点之间都存在一条边,或有向图中每两个顶点之间都存在着方向相反的两条边,则称此图为完全图。

(4)稠密图和稀疏图①稠密图当一个图接近完全图时,称为稠密图。

②稀疏图当一个图含有较少的边数(即当e<<n(n-1))时,则称为稀疏图。

(5)子图设有两个图G=(V,E)和G′=(V′,E′),若V′是V的子集,即V′≤V,且E′是E的子集,即E′≤E,则称G′是G的子图。

(6)路径和路径长度①路径在一个图G=(V,E)中,从顶点i到顶点j的一条路径是一个顶点序列(i,i1,i2,…,i m),若此图G是无向图,则边(i,i1),(i1,i2),…,(i m-1,i m),(i m,j)属于E(G);若此图是有向图,N<i,i1>,<i1,i2>,…,<i m-1,i m>,<i m,j>属于E(G)。

②路径长度路径长度是指一条路径上经过的边的数目。

(7)回路或环若一条路径上的开始点与结束点为同一个顶点,则称此路径为回路或环。

数据结构(李春葆)习题与解析

数据结构(李春葆)习题与解析

数据结构(李春葆)习题与解析一、绪论选择题1.数据结构是一门研究非数值计算的程序设计问题计算机的以及它们之间的和运算等的学科。

1A.数据元素B.计算方法C.逻辑存储D.数据映像2A.结构B.关系C.运算D.算法2.数据结构被形式地定义为(K,R),其中K是的有限集,R是K上的有限集。

1A.算法B.数据元素C.数据操作D.逻辑结构2A.操作B.映像C.存储D.关系3.在数据结构中,从逻辑上可以把数据结构分成。

A.动态结构和静态结构B.紧凑结构和非紧凑结构C.线性结构和非线性结构D.内部结构和外部结构4.线性结构的顺序存储结构是一种的存储结构,线性表的链式存储结构是一种的存储结构。

A.随机存取B.顺序存取C.索引存取D.散列存取5.算法分析的目的是,算法分析的两个主要方面是。

1A.找出数据结构的合理性B.研究算法中的输入和输出的关系C.分析算法的效率以求改进D.分析算法的易懂性和文档性2A.空间复杂度和时间复杂度B.正确性和简单性C.可读性和文档性D.数据复杂性和程序复杂性6.计算机算法指的是,它必须具备输入、输出和等5个特性。

1A.计算方法B.排序方法C.解决问题的有限运算序列D.调度方法2A.可执行性、可移植性和可扩充性B.可行性、确定性和有穷性C.确定性、有穷性和稳定性D.易读性、稳定性和安全性7.线性表的逻辑顺序与存储顺序总是一致的,这种说法。

A.正确B.不正确8线性表若采用链式存储结构时,要求内存中可用存储单元的地址。

A.必须连续的B.部分地址必须连续的C.一定是不续的D连续不连续都可以9.以下的叙述中,正确的是。

A.线性表的存储结构优于链式存储结构B.二维数组是其数据元素为线性表的线性表C.栈的操作方式是先进先出D.队列的操作方式是先进后出10.每种数据结构都具备三个基本运算:插入、删除和查找,这种说法。

A.正确B.不正确填空题1.数据逻辑结构包括三种类型、和,树形结构和图形结构合称为。

李春葆《数据结构教程》(C++语言描述)配套题库【课后习题】(外排序)

李春葆《数据结构教程》(C++语言描述)配套题库【课后习题】(外排序)

第10章外排序一、单项选择题(1)以下关于外排序的叙述正确的是______。

A.外排序把外存文件调入内存,再利用内排序方法进行排序,所以外排序所花的时间完全由采用的内排序确定B.外排序所花的时间=内排序时间+外存信息读/写时间+内部归并所花的时间C.外排序并不涉及文件的读/写操作D.外排序完全可以由内排序来替代【答案】B【解析】外排序所花的时间由内排序时间、外存读写时间、内部归并时间三部分时间构成,因此AC两项错误,B项正确;外排序要将文件读取到内存中进行排序,但是由于文件大小可能会大于内存的最大容量,因此外排序不能完全由内排序替代。

(2)如果将一个由置换-选择排序得到的输出文件F1(含所有初始归并段)作为输入文件再次进行置换-选择排序,得到输出文件F2(含所有初始归并段),则F1和F2的差异是______。

A.F2中归并段的个数减少B.F2中归并段的最大长度增大C.F2和F1无差异D .归并段个数及各归并段长度均不变,但F 2中可能存在与F 1不同的归并段【答案】C 【解析】当进行一次置换-选择排序后,文件的归并段即达到理想状态,无论再进行多少次排序,均不会发生变化,因此答案为C 项。

(3)采用败者树进行k 路平衡归并的外排序算法,其总的归并效率与k______。

A .有关B .无关【答案】A【解析】利用败者树进行k 路平衡归并不会影响总共需要的关键字比较次数,但是随着k 的增大,归并树的高度会减小,磁盘读/写的次数也就相应减少,从而提高总的归并效率,因此答案为A 项。

(4)对m 个初始归并段实施k 路平衡归并排序,所需的归并趟数是______。

A .1B .m/kC ./m k ⎡⎤⎢⎥D .log k m ⎡⎤⎢⎥【答案】D【解析】采用k 路归并,相应的归并树就有log k m ⎡⎤⎢⎥+1层,则需要归并的趟数为log k m ⎡⎤⎢⎥,答案为D 项。

(5)设有100个初始归并段,如果采用k 路平衡归并3趟完成排序,则k 值最小是______。

数据结构简明教程(李春葆版)课后习题答案

数据结构简明教程(李春葆版)课后习题答案

数据结构简明教程(第2版)配套练习题参考答案———————数据结构简明教程———————1.练习题1参考答案1.单项选择题(1)D (2)C (3)C (4)A (5)C (6)B (7)C (8)A (9)C (10)B 2.填空题(1)①逻辑结构 ②存储结构 ③运算(不限制顺序)(2)①线性结构 ②非线性结构(不限制顺序)(3)①数据元素 ②关系(4)①没有 ②没有(5)①前驱 ②一 ③后继 ④任意多个(6)任意多个(7)①顺序 ②链式 ③索引 ④哈希(不限制顺序)(8)①时间 ②空间(不限制顺序)(9)问题规模(通常用n 表示)。

(10)辅助或临时空间3.简答题(1)答:运算描述是指逻辑结构施加的操作,而运算实现是指一个完成该运算功能的算法。

它们的相同点是,运算描述和运算实现都能完成对数据的“处理”或某种特定的操作。

不同点是,运算描述只是描述处理功能,不包括处理步骤和方法,而运算实现的核心则是处理步骤。

(2)答:T 1(n )=O(n log 2n ),T 2(n )=O( ),T 3(n )=O(n 2),T 4(n )=O(n log 2n )。

(3)答:j =0,第1次循环:j =1,s =10。

第2次循环:j =2,s =30。

第3次循环:j =3,s =60。

第4次循环:j =4,s =100。

while 条件不再满足。

所以,其中循环语句的执行次数为4。

(4)答:语句s ++的执行次数2)2)(3(3)1()1(12121-+=++-+=+-=∑∑∑-=-==n n n n i n n i n i i nj。

(5)答:其中x ++语句为基本运算语句,∑∑∑=+==-=-==n i n i j ni n n i n n T 1112)1()(1)(=O(n 2)。

(6) 答:由于内循环j 的取值范围,所以i ≤n /2,则,该程序段的时间复杂度为O(n 2)。

∑∑∑-===--==2/122/124/))12((n i nij n i n i n m 3log 2n2.练习题2参考答案1.单项选择题(1)A (2)C (3)A (4)B (5)C(6)D (7)C (8)B (9)A (10)C(11)B (12)A (13)C (14)D (15)D(16)D (17)A (18)C (19)A (20)D2.填空题(1)L.length=0(2)O(1)(3)O(n)(4)n-i(5)①物理存储位置②指针域(6)①前驱 ②O(n)(7)q=p->next; p->next=q->next; free(q);(8)s->next= p->next; p->next=s;(9)O(1)(10)L->next==L3.简答题(1)答:顺序存储结构中,逻辑上相邻元素的存储空间也是相邻的,无需额外空间表示逻辑关系,所以存储密度大,同时具有随机存取特性。

数据结构第10章 习题答案

数据结构第10章 习题答案

1.下列排序算法中,其中( D )是稳定的。

A. 堆排序,冒泡排序B. 快速排序,堆排序C. 直接选择排序,归并排序D. 归并排序,冒泡排序2.有一组数据(15,9,7,8,20,-1,7,4)用快速排序的划分方法进行一趟划分后数据的排序为 ( A )(按递增序)。

A.下面的B,C,D都不对。

B.9,7,8,4,-1,7,15,20C.20,15,8,9,7,-1,4,7 D. 9,4,7,8,7,-1,15,203.下列排序算法中,在每一趟都能选出一个元素放到其最终位置上,并且其时间性能受数据初始特性影响的是:( B )。

A. 直接插入排序B. 快速排序C. 直接选择排序D. 堆排序4.如果只想得到1000个元素组成的序列中第5个最小元素之前的部分排序的序列,用( D )方法最快。

A.起泡排序 B.快速排列 C.Shell排序 D.堆排序 E.简单选择排序5.从未排序序列中依次取出一个元素与已排序序列中的元素依次进行比较,然后将其放在已排序序列的合适位置,该排序方法称为( A )排序法。

A. 插入B. 选择C. 希尔D. 二路归并6. 在排序算法中,每次从未排序的记录中挑出最小(或最大)关键码字的记录,加入到已排序记录的末尾,该排序方法是( A )。

A. 选择B. 冒泡C. 插入D. 堆7. 若用冒泡排序方法对序列{10,14,26,29,41,52}从大到小排序,需进行( C )次比较。

A. 3B. 10C. 15D. 258. 对序列{15,9,7,8,20,-1,4,} 用希尔排序方法排序,经一趟后序列变为{15,-l,4,8,20,9,7}则该次采用的增量是 ( B )A. lB. 4C. 3D. 29. 堆排序是( E )类排序A. 插入B. 交换C. 归并D. 基数E. 选择10.排序方法有许多种,(1)法从未排序的序列中依次取出元素,与已排序序列(初始时为空)中的元素作比较,将其放入已排序序列的正确位置上;(2)法从未排序的序列中挑选元素,并将其依次放入已排序序列(初始时为空)的一端;交换排序方法是对序列中的元素进行一系列比较,当被比较的两元素逆序时,进行交换;(3)和(4)是基于这类方法的两种排序方法,而(4)是比(3)效率更高的方法;(5)法是基于选择排序的一种排序方法,是完全二叉树结构的一个重要应用。

数据结构教程李春葆课后答案第10章内排序

数据结构教程李春葆课后答案第10章内排序

2 else d=d/3; } }
数据结构教程学习指导
(1)指出fun(a,n)算法的功能。 (2)当a[]={5,1,3,6,2,7,4,8}时,问fun(a,8)共执行几趟排序,各趟的排序 结果是什么? 答:(1)fun(a,n)算法的功能是采用增量递减为1/3的希尔排序方法对a数组中元素进 行递增排序。 (2)当a[]={5,1,3,6,2,7,4,8}时,执行fun(a,8)的过程如下: d=2:2 1 3 6 4 7 5 8 d=1:1 2 3 4 5 6 7 8 共有两趟排序。 4. 在实现快速排序的非递归算法时,可根据基准元素,将待排序序列划分为两个子 序列。若下一趟首先对较短的子序列进行排序,试证明在此做法下,快速排序所需要的栈 的深度为 O(log2n)。 答:由快速排序的算法可知,所需递归工作栈的深度取决于所需划分的最大次数。在 排序过程中每次划分都把整个待排序序列根据基准元素划分为左、右两个子序列,然后对 这两个子序列进行类似的处理。 设S(n)为对n个记录进行快速排序时平均所需栈的深度, 则: S(n)=
KeyType QuickSelect(RecType R[],int s,int t,int k) //在 R[s..t]序列中找第 k 小的元素 { int i=s,j=t; RecType tmp; if (s<t) //区间内至少存在 2 个元素的情况 { tmp=R[s]; //用区间的第 1 个记录作为基准 while (i!=j) //从区间两端交替向中间扫描,直至 i=j 为止 { while (j>i && R[j].key>=tmp.key) j--; //从右向左扫描,找第 1 个关键字小于 tmp 的 R[j] R[i]=R[j]; //将 R[j]前移到 R[i]的位置 while (i<j && R[i].key<=tmp.key) i++; //从左向右扫描,找第 1 个关键字大于 tmp 的 R[i] R[j]=R[i]; //将 R[i]后移到 R[j]的位置 } R[i]=tmp; if (k-1==i) return R[i].key; else if (k-1<i) return QuickSelect(R,s,i-1,k); //在左区间中递归查找 else return QuickSelect(R,i+1,t,k); //在右区间中递&& s==k-1) return R[k-1].key; else return -1; }

数据结构第九、十章作业答案

数据结构第九、十章作业答案

第九章查找一、填空题1.在数据的存放无规律而言的线性表中进行检索的最佳方法是顺序查找(线性查找) 。

2.线性有序表(a i,a2,a3,…,a256)是从小到大排列的,对一个给定的值k,用二分法检索表中与k相等的元素,在查找不成功的情况下,最多需要检索_8 次。

设有100个结点,用二分法查找时,最大比较次数是_7_ ____________ 。

3•假设在有序线性表a[1..2O]上进行折半查找,则比较一次查找成功的结点数为1;比较两次查找成功的结点数为_2 ___________ ;比较四次查找成功的结点数为8 ,其下标从小到大依次是1,3,6,8,11,13,16,19 _ ,平均查找长度为 3.7 。

解:显然,平均查找长度二0( log 2n) <5次(25)。

但具体是多少次,则不应当按照公式ASL =U|°g2(n⑴来计算(即(21 X log 221) /20 = 4.6次并不正确!)。

因为这是在假设n = 2m-1 n 的情况下推导出来的公式。

应当用穷举法罗列:全部元素的查找次数为=(1 + 2X 2+ 4X 3+ 8X 4+ 5X 5)= 74; ASL= 74/20=3.7 !!! 4•折半查找有序表(4, 6,12,20, 28, 38,50,70, 88,100),若查找表中元素20,它将依次与表中元素28 , 6, 12, 20 比较大小。

5. 在各种查找方法中,平均查找长度与结点个数n无关的查找方法是散列查找。

6. 散列法存储的基本思想是由关键字的值决定数据的存储地址。

7. 有一个表长为m的散列表,初始状态为空,现将n (n<m)个不同的关键码插入到散列表中,解决冲突的方法是用线性探测法。

如果这n个关键码的散列地址都相同,贝U探测的总次数是n(n-1)/2= ( 1 土2+…+ n-1 )。

(而任一元素查找次数 < n-1)&设一哈希表表长M为100,用除留余数法构造哈希函数,即H( K) =K MOIP ( P<=M ,为使函数具有较好性能,P应选(97 )9、在各种查找方法中,平均查找长度与结点个数无关的是哈_______10、对线性表进行二分查找时,要求线性表必须以顺序方式存储,且结点按关键字有序排列。

李春葆《数据结构教程》(第4版)课后习题-第一章至第十二章(圣才出品)

李春葆《数据结构教程》(第4版)课后习题-第一章至第十二章(圣才出品)

第二部分课后习题第1章绪论1.简述数据与数据元素的关系与区别。

答:凡是能被计算机存储、加工的对象统称为数据,数据是一个集合。

数据元素是数据的基本单位,是数据的个体。

数据与元素之间的关系是元素与集合之间的关系。

2.数据结构和数据类型有什么区别?答:数据结构是互相之间存在一种或多种特定关系的数据元素的集合,一般包括三个方面的内容,即数据的逻辑结构、存储结构和数据的运算。

而数据类型是一个值的集合和定义在这个集合上的一组运算的总称,如C语言中的int数据类型是由-32768~32767(16位机)的整数和+、-、*、/、%等运算符组成。

3.设3个表示算法频度的函数f、g和h分别为:f(n)=100n3+n2+1000g(n)=25n3+5000n2h(n)=n1.5+5000nlog2n求它们对应的时间复杂度。

答:f(n)=100n3+n2+1000=O(n3),g(n)=25n3+5000n2=O(n3),当n→∞时,√n>log2n,所以h(n)=n1.5+5000nlog2n=O(n1.5)。

4.用C/C++语言描述下列算法,并给出算法的时间复杂度。

(1)求一个n阶方阵的所有元素之和。

(2)对于输入的任意三个整数,将它们按从小到大的顺序输出。

(3)对于输入的任意n个整数,输出其中的最大和最小元素。

答:(1)算法如下:本算法的时间复杂度为O(n2)。

(2)算法如下:本算法的时间复杂度为O(1)。

(3)算法如下:本算法的时间复杂度为O(n)。

5.设n为正整数,给出下列各种算法关于n的时间复杂度。

(1)(2)(3)答:(1)设while循环语句执行次数为T(n),则:(2)算法中的基本运算语句是if(b[k]>b[j])k=j,其执行次数T(n)为:(3)设while循环语句执行次数为T(n),则:则6.有以下递归算法用于对数组a[i..j]的元素进行归并排序:求mergesort(a,0,n-1)的时间复杂度。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

13. 对于给定的含有 n 元素的无序数据序列(所有元素的关键字不相同),利用快速 排序方法求这个序列中第 k(1≤k≤n)小元素的关键字,并分析所设计算法的最好和平均 时间复杂度。 解: 采用快速排序思想求解,当划分的基准元素为 R[i]时,根据 i 与 k 的大小关系再 在相应的子区间中查找。对应的算法如下:
void fun(int a[],int n,int b[]) { int i; for (i=0;i<n;i++) b[a[i]-1]=a[i]; }
11. 设计一个双向冒泡排序的算法,即在排序过程中交替改变扫描方向。 解:置 i 的初值为 0,先从后向前从无序区 R[i..n-i-1]归位一个最小元素 R[i]到有序区 R[0..i-1],再从前向后从无序区 R[i..n-i-1]归位一个最大元素到有序区 R[n-i..n-1]。当某趟 没有元素交换时,则结束;否则将 i 增加 1。对应的算法如下:
1 n

k 1
n
( S (k 1) S (n k ))
2 n
S (i)
i 0
n 1
当n=1时,所需栈空间为常量,由此可推出:S(n)=O(log2n)。 实际上,在快速排序中下一趟首先对较短子序列排序,并不会改变所需栈的深度,所 以所需栈的深度仍为O(log2n)。 5. 将快速排序算法改为非递归算法时通常使用一个栈,若把栈换为队列会对最终排序 结果有什么影响? 答:在执行快速排序算法时,用栈保存每趟快速排序划分后左、右子区间的首、尾地 址,其目的是为了在处理子区间时能够知道其范围,这样才能对该子区间进行排序,但这 与处理子区间的先后顺序没什么关系,而仅仅起存储作用(因为左、右子区间的处理是独 立的)。因此,用队列同样可以存储子区间的首、尾地址,即可以取代栈的作用。在执行 快速排序算法时,把栈换为队列对最终排序结果不会产生任何影响。 6. 在堆排序、快速排序和二路归并排序中: (1)若只从存储空间考虑,则应首先选取哪种排序方法,其次选取哪种排序方法,最 后选取哪种排序方法? (2)若只从排序结果的稳定性考虑,则应选取哪种排序方法? (3)若只从最坏情况下的排序时间考虑,则不应选取哪种排序方法? 答:(1)若只从存储空间考虑,则应首先选取堆排序(空间复杂度为O(1)),其次选 取快速排序(空间复杂度为O(log2n)),最后选取二路归并排序(空间复杂度为O(n))。 (2)若只从排序结果的稳定性考虑,则应选取二路归并排序,其他两种排序方法是不
第 10 章 内排序 } for (j=i;j<n-i-1;j++) if (R[j].key>R[j+1].key) { exchange=true; swap(R[j],R[j+1]); } if (!exchange) return; i++; } }
5
//由前向后冒泡大元素 //R[j]和 R[j+1]交换
第 10 章 内排序
3
稳定的。 (3)若只从最坏情况下的排序时间考虑,则不应选取快速排序方法。因为快速排序方 法最坏情况下的时间复杂度为 O(n2) ,其他两种排序方法在最坏情况下的时间复杂度为 O(nlog2n)。 7. 如果只想在一个有 n 个元素的任意序列中得到其中最小的第 k(k<<n)个元素之前 的部分排序序列,那么最好采用什么排序方法?为什么?例如有这样一个序列(57,40, 38,11,13,34,48,75,6,19,9,7),要得到其第 4 个元素(k=4)之前的部分有序 序列,用所选择的算法实现时,要执行多少次比较? 答:采用堆排序最合适,建立初始堆(小根堆)所花时间不超过4n,每次选出一个最 小 元 素 所 花 时间 为 log2n , 因 此 得 到 第 k 个 最 小 元素 之 前 的 部 分序 列 所 花时 间 大 约为 4n+klog2n,而冒泡排序和简单选择排序所花时间为kn。 对于序列(57,40,38,11,13,34,48,75,6,19,9,7),形成初始堆(小根堆) 并选最小元素6,需进行18次比较;选次小元素7时,需进行5次比较;再选元素9时,需进 行6次比较;选元素11时,需进行4次比较,总共需进行33次比较。整个过程如图10.2所示。
KeyType QuickSelect(RecType R[],int s,int t,int k) //在 R[s..t]序列中找第 k 小的元素 { int i=s,j=t; RecType tmp; if (s<t) //区间内至少存在 2 个元素的情况 { tmp=R[s]; //用区间的第 1 个记录作为基准 while (i!=j) //从区间两端交替向中间扫描,直至 i=j 为止 { while (j>i && R[j].key>=tmp.key) j--; //从右向左扫描,找第 1 个关键字小于 tmp 的 R[j] R[i]=R[j]; //将 R[j]前移到 R[i]的位置 while (i<j && R[i].key<=tmp.key) i++; //从左向右扫描,找第 1 个关键字大于 tmp 的 R[i] R[j]=R[i]; //将 R[i]后移到 R[j]的位置 } R[i]=tmp; if (k-1==i) return R[i].key; else if (k-1<i) return QuickSelect(R,s,i-1,k); //在左区间中递归查找 else return QuickSelect(R,i+1,t,k); //在右区间中递归查找 }
57 建初始堆 40 11 13 34 38 48 11 9 13 34 7 48 6
75
6
19
9
7 38
75
40
19
57
38 7
6,38 交换 11 75
9 13 40 19 57 57 34
7 48
调整堆
9 11 13 40 19 57 9 38
34 48
75
7,57 交换
9 11 13 38
34 48
void fun(int a[],int n) { int i,j,d,tmp; d=n/3; while (true) { for (i=d;i<n;i++) { tmp=a[i]; j=i-d; while (j>=0 && tmp<a[j]) { a[j+d]=a[j]; j=j-d; } a[j+d]=tmp; } if (d==1) break; else if (d<3) d=1;
第 10 章 内排序
教材中练习题及参考答案
1. 直接插入排序算法在含有n个元素的初始数据正序、反序和数据全部相等时,时间 复杂度各是多少? 答:含有n个元素的初始数据正序时,直接插入排序算法的时间复杂度为O(n)。 含有n个元素的初始数据反序时,直接插入排序算法的时间复杂度为O(n2)。 含有n个元素的初始数据全部相等时,直接插入排序算法的时间复杂度为O(n)。 2. 回答以下关于直接插入排序和折半插入排序的问题: (1)使用折半插入排序所要进行的关键字比较次数,是否与待排序的元素的初始状态 有关? (2)在一些特殊情况下,折半插入排序比直接插入排序要执行更多的关键字比较,这 句话对吗? 答:(1)使用折半插入排序所要进行的关键字比较次数,与待排序的元素的初始状态 无关。无论待排序序列是否有序,已形成的部分子序列是有序的。折半插入排序首先查找 插入位置,插入位置是判定树失败的位置(对应外部节点),失败位置只能在判定树的最 下两层上。 (2)一些特殊情况下,折半插入排序的确比直接插入排序需要更多的关键字比较,例 如,在待排序序列正序的情况下便是如此。 3. 有以下关于排序的算法:
2 else d=d/3; } }
数据结构教程学习指导
(1)指出fun(a,n)算法的功能。 (2)当a[]={5,1,3,6,2,7,4,8}时,问fun(a,8)共执行几趟排序,各趟的排序 结果是什么? 答:(1)fun(a,n)算法的功能是采用增量递减为1/3的希尔排序方法对a数组中元素进 行递增排序。 (2)当a[]={5,1,3,6,2,7,4,8}时,执行fun(a,8)的过程如下: d=2:2 1 3 6 4 7 5 8 d=1:1 2 3 4 5 6 7 8 共有两趟排序。 4. 在实现快速排序的非递归算法时,可根据基准元素,将待排序序列划分为两个子 序列。若下一趟首先对较短的子序列进行排序,试证明在此做法下,快速排序所需要的栈 的深度为 O(log2n)。 答:由快速排序的算法可知,所需递归工作栈的深度取决于所需划分的最大次数。在 排序过程中每次划分都把整个待排序序列根据基准元素划分为左、右两个子序列,然后对 这两个子序列进行类似的处理。 设S(n)为对n个记录进行快速排序时平均所需栈的深度, 则: S(n)=
void DBubbleSort(RecType R[],int n) //对 R[0..n-1]按递增序进行双向冒泡排序 { int i=0,j; bool exchange=true; //exchange 标识本趟是否进行了元素交换 while (exchange) { exchange=false; for (j=n-i-1;j>i;j--) if (R[j].key<R[j-1].key) //由后向前冒泡小元素 { exchange=true; swap(R[j],R[j-1]); //R[j]和 R[j-1]交换
12. 假设有 n 个关键字不同的记录存于顺序表中,要求不经过整体排序而从中选出从 大到小顺序的前 m(m<<n)个元素。试采用简单选择排序算法实现此选择过程。 解:改进后的简单选择排序算法如下:
void SelectSort1(RecType R[],int n,int m) { int i,j,k; for (i=0;i<m;i++) //做第 i 趟排序 { k=i; for (j=i+1;j<n;j++) //在当前无序区 R[i..n-1]中选 key 最大的 R[k] if (R[j].key>R[k].key) k=j; //k 记下目前找到的最大关键字所在的位置 if (k!=i) swap(R[i],R[k]); //交换 R[i]和 R[k] } }
相关文档
最新文档