第9章排序自测卷答案姓名班级
一、填空题(每空1分,共24分)
1. 大多数排序算法都有两个基本的操作:比较(两个关键字的大小)和移动(记录或改变指向记录的指
针)。
2.在对一组记录(54,38,96,23,15,72,60,45,83)进行直接插入排序时,当把第7个记录60插入
到有序表时,为寻找插入位置至少需比较 3次。(可约定为,从后向前比较)
3.在插入和选择排序中,若初始数据基本正序,则选用插入排序(到尾部);若初始数据基本反序,则选
用选择排序。
4.在堆排序和快速排序中,若初始记录接近正序或反序,则选用;若初始记录基本无序,则最好选
用快速排序。
5.对于n个记录的集合进行冒泡排序,在最坏的情况下所需要的时间是2。若对其进行快速排序,在
最坏的情况下所需要的时间是O(n2。
6.对于n个记录的集合进行归并排序,所需要的平均时间是,所需要的附加空间是。 7.【计研题2000】对于n个记录的表进行2路归并排序,整个归并排序需进行,共计移 动n log次记录。
(即移动到新表中的总次数!共log2n趟,每趟都要移动n个元素)
8.设要将序列(Q, H, C, Y, P, A, M, S, R, D, F, X)中的关键码按字母序的升序重新排列,则: 冒泡排序一趟扫描的结果是 H, C, Q, P, A, M, S, R, D, F, X ,Y;
初始步长为4的希尔(shell)排序一趟的结果是P, A, C, S, Q, D, F, X , R, H,M, Y; 二路归并排序一趟扫描的结果是H, Q, C, Y,A, P, M, S, D, R, F, X ; 快速排序一趟扫描的结果是F, H, C, D, P, A, M, Q, R, S, Y,X; 堆排序初始建堆的结果是A, D, C, R, F, Q, M, S, Y,P, H, X。
9. 在堆排序、快速排序和归并排序中,
若只从存储空间考虑,则应首先选取堆排序方法,其次选取快速排序方法,最后选取归并排序方法; 若只从排序结果的稳定性考虑,则应选取归并排序方法; 若只从平均情况下最快考虑,则应选取快速排序方法;
若只从最坏情况下最快并且要节省内存考虑,则应选取堆排序方法。
二、单项选择题(每小题1分,共18分)
(C)1.将5个不同的数据进行排序,至多需要比较次。
A. 8 B. 9 C. 10 D. 25
(C)2.排序方法中,从未排序序列中依次取出元素与已排序序列(初始时为空)中的元素进行比较,将
其放入已排序序列的正确位置上的方法,称为 A.希尔排序B.冒泡排序C. 插入排序D. 选择排序