科学管理合理组织,不断深化“双基”建设,狠抓安全技术教育培训工作,全面落实“手指口述安全确认操作、岗位描述”安全管理规范,提高全员安全责任意识和整体操作技能。
第 9 章 排序 自测卷 答案 姓名 班级
一、填空题(每空 1 分,共 24 分)
1. 大多数排序算法都有两个基本的操作: 比较(两个关键字的大小) 和 移动(记录或改变指向记
录的指针) 。
2. 在对一组记录(54,38,96,23,15,72,60,45,83)进行直接插入排序时,当把第 7 个记录 60 插
入到有序表时,为寻找插入位置至少需比较 3 次。(可约定为,从后向前比较)
3. 在插入和选择排序中,若初始数据基本正序,则选用 插入排序(到尾部) ;若初始数据基本反序,
则选用 选择排序 。
4. 在堆排序和快速排序中,若初始记录接近正序或反序,则选用 堆排序 ;若初始记录基本无序,则
最好选用 快速排序 。
5. 对于 n 个记录的集合进行冒泡排序,在最坏的情况下所需要的时间是 O(n
2
) 。若对其进行快速排序,
在最坏的情况下所需要的时间是 O(n
2
) 。
6. 对于 n 个记录的集合进行归并排序,所需要的平均时间是 O(nlog
2
n) ,所需要的附加空间是 O(n) 。
7.【计研题 2000】对于 n 个记录的表进行 2 路归并排序,整个归并排序需进行 log
2
n 趟(遍),共计移
动 n log
2
n
次记录。
(即移动到新表中的总次数!共 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. 选择排序