c语言哪些排序方法与初始序列有关,数据结构(C语言)-第10章排序自测题

计算机语言-数据结构

第9章 排序 自测卷 姓名 班级

1-75-jpg_6_0_______-616-0-0-616.jpg

一、填空题(每空1分,共24分)

1. 大多数排序算法都有两个基本的操作:

2. 在对一组记录(54,38,96,23,15,72,60,45,83)进行直接插入排序时,当把第7个记录60插

入到有序表时,为寻找插入位置至少需比较 次。

3. 在插入和选择排序中,若初始数据基本正序,则选用若初始数据基本反序,则选用。

4. 在堆排序和快速排序中,若初始记录接近正序或反序,则选用最好选用 。

5. 对于n个记录的集合进行冒泡排序,在最坏的情况下所需要的时间是。若对其进行快速排序,在

最坏的情况下所需要的时间是 。

6. 对于n个记录的集合进行归并排序,所需要的平均时间是,所需要的附加空间是

7. 对于n个记录的表进行2路归并排序,整个归并排序需进行趟(遍)。

8. 设要将序列(Q, H, C, Y, P, A, M, S, R, D, F, X)中的关键码按字母序的升序重新排列,则:

冒泡排序一趟扫描的结果是 HCQPYAMRDFSX ;

初始步长为4的希尔(shell)排序一趟的结果是 ;

二路归并排序一趟扫描的结果是 ;

快速排序一趟扫描的结果是 ;

堆排序初始建堆的结果是 。

9. 在堆排序、快速排序和归并排序中, 若只从存储空间考虑,则应首先选取 堆排序 方法,其次选取 快速排序 方法,最后选取 归并排序 方法; 若只从排序结果的稳定性考虑,则应选取 归并排序 方法;

若只从平均情况下最快考虑,则应选取 归并排序 方法;

若只从最坏情况下最快并且要节省内存考虑,则应选取 快速排序 方法。

二、单项选择题(每小题1分,共18分)

( 1.5不同的数据进行排序,至多需要比较 次。

A. 8 B. 9 C. 10 D. 25

( )2. 排序方法中,从未排序序列中依次取出元素与已排序序列(初始时为空)中的元素进行比较,

将其放入已排序序列的正确位置上的方法,称为

A. 希尔排序 B. 冒泡排序 C. 插入排序 D. 选择排序

( )3.从未排序序列中挑选元素,并将其依次插入已排序序列(初始时为空)的一端的方法,称为

A. 希尔排序 B. 归并排序 C. 插入排序 D. 选择排序

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值