数据结构题目收录(二十三)
admin
2024-02-12 01:28:33
0

1、排序过程中,对尚未确定最终位置的所有元素进行一遍处理称为以“趟”。下列序列中,不可能是快速排序第二趟结果的是()。

  • A:5,2,16,12,28,60,32,72
  • B:2,16,5,28,12,60,32,72
  • C:2,12,16,5,28,32,72,60
  • D:5,2,12,28,16,32,72,60
解析
答案:D

2、简单选择排序算法的比较次数和移动次数分别为()。

  • A:O(n),O(log⁡2n\log_2nlog2​n)
  • B:O(log⁡2n\log_2nlog2​n),O(n2n^2n2)
  • C:O(n2n^2n2),O(n)
  • D:O(nlog⁡2n\log_2nlog2​n),O(n)
解析
答案:C

3、设线性表中每个元素有两个数据项k1k_1k1​和k2k_2k2​,现对线性表按以下规则进行排序:先看数据项k1k_1k1​,k1k_1k1​值小的元素在前,大的元素在后;在k1k_1k1​值相同的情况下,再看k2k_2k2​,k2k_2k2​值小的在前,大的元素在后。满足这种要求的排序方法是()。

  • A:先按k1k_1k1​进行直接插入排序,再按k2k_2k2​进行简单选择排序
  • B:先按k2k_2k2​进行直接插入排序,再按k1k_1k1​进行简单选择排序
  • C:先按k1k_1k1​进行简单选择排序,再按k2k_2k2​进行直接插入排序
  • D:先按k2k_2k2​进行简单选择排序,再按k1k_1k1​进行直接插入排序
解析

本题思路来自基数排序的LSD,首先应该确定k1k_1k1​、k2k_2k2​的排序顺序,若先排k1k_1k1​再排k2k_2k2​,则排序结果不符合题意,排除A和C。

再考虑算法的稳定性,当k2k_2k2​排好序后,再对k1k_1k1​排序,若对k1k_1k1​排序采用的算法是不稳定的,则对于k1k_1k1​相同而k2k_2k2​不同的元素可能会改变相对次序,从而不一定能满足题设要求。

直接插入排序算法是稳定的,而简单选择排序算法是不稳定的,故只能选D。

答案:D

4、在含有n个关键字的小根堆中,关键字最大的记录有可能存储在()位置。

  • A:n/2
  • B:n/2+2
  • C:1
  • D:n/2-1
解析

这是小根堆,关键字最大的记录一定存储在这个堆所对应的完全二叉树的叶子结点中;又因为二叉树中的最后一个非叶子结点存储在⌊n/2⌋\lfloor{n/2}\rfloor⌊n/2⌋中,所以关键字最大记录的存储范围为⌊n/2⌋\lfloor{n/2}\rfloor⌊n/2⌋+1~n,所以应该选B。

答案:B

5、向具有n个结点的堆中插入一个新元素的时间复杂度为(),删除一个元素的时间复杂度为()。

  • A:O(1)
  • B:O(n)
  • C:O(log⁡2n\log_2nlog2​n)
  • D:O(nlog⁡2n\log_2nlog2​n)
解析

在向有n个元素的堆中插入一个新元素时,需要调用一个向上调整的算法,比较次数最多等于树的高度减1,由于树的高度为⌊log⁡2n⌋\lfloor{\log_2n}\rfloor⌊log2​n⌋+1,所以堆的向上调整算法的比较次数最多等于⌊log⁡2n⌋\lfloor{\log_2n}\rfloor⌊log2​n⌋。此处需要注意,调整堆和建初始堆的时间复杂度是不一样的。

答案:C,C

6、构建n个记录的初始堆,其时间复杂度为();对n个记录进行堆排序,最坏情况下其时间复杂度为()。

  • A:O(n)
  • B:O(n2n^2n2)
  • C:O(log⁡2n\log_2nlog2​n)
  • D:O(nlog⁡2n\log_2nlog2​n)
解析

建堆过程中,向下调整的时间与树高h有关,为O(h)。每次向下调整时,大部分结点的高度都较小。因此,可以证明在元素个数为n的序列上建堆,其时间复杂度为O(n)。无论是在最好情况下还是在最坏情况下,堆排序的时间复杂度均为O(nlog⁡2nn\log_2nnlog2​n)。

答案:A,D

7、对关键码序列{23,17,72,60,25,8,68,71,52}进行堆排序,输出两个最小关键码后的剩余堆是()。

  • A:{23,72,60,25,68,71,52}
  • B:{23,25,52,60,71,72,68}
  • C:{71,25,23,52,60,72,68}
  • D:{23,25,68,52,60,72,71}
解析

筛选法初始建堆为{8,17,23,52,25,72,68,71,60},输出8后重建的堆为{17,25,23,52,60,72,68,71},输出17后重建的堆为{23,25,68,52,60,72,71}。

答案:D

8、已知序列25,13,10,12,9是大根堆,在序列尾部插入新元素18,将其再调整为大根堆,调整过程中元素之间进行的比较次数是()。

  • A:1
  • B:2
  • C:4
  • D:5
解析

首先18与10比较,交换位置,再与25比较,不交换位置。一共比较了2次。

答案:B

9、在下列4种排序方法中,排序过程中的比较次数与序列初始状态无关的是()。

  • A:选择排序法
  • B:插入排序法
  • C:快速排序法
  • D:冒泡排序法
解析

选择排序算法的比较次数始终为n(n-1)/2,与序列状态无关。

答案:A

10、已知小根堆为8,15,10,21,34,16,12,删除关键字8之后需要重建堆,在此过程中,关键字之间的比较次数是()。

  • A:1
  • B:2
  • C:3
  • D:4
解析
答案:C

相关内容

热门资讯

安卓系统用的华为应用,探索智能... 你知道吗?在安卓系统里,华为的应用可是个宝库呢!它们不仅功能强大,而且使用起来超级方便。今天,就让我...
安卓变ios系统魅蓝 你知道吗?最近有个朋友突然告诉我,他要把自己的安卓手机换成iOS系统,而且还是魅蓝品牌的!这可真是让...
幻书启世录安卓系统,安卓世界中... 亲爱的读者们,你是否曾在某个夜晚,被一本神奇的书所吸引,仿佛它拥有着穿越时空的力量?今天,我要带你走...
电脑安装安卓系统进不去,安卓系... 电脑安装安卓系统后竟然进不去,这可真是让人头疼的问题啊!你是不是也遇到了这种情况,心里直呼“怎么办怎...
用键盘切换控制安卓系统,畅享安... 你有没有想过,用键盘来控制你的安卓手机?是的,你没听错,就是那个我们每天敲敲打打的小玩意儿——键盘。...
小米安卓镜像系统在哪,小米安卓... 你有没有想过,你的小米手机里有一个隐藏的宝藏——安卓镜像系统?没错,就是那个可以让你的手机瞬间变身成...
安卓手机下载排班系统,高效排班... 你有没有想过,每天忙碌的工作中,有没有什么好帮手能帮你轻松管理时间呢?今天,就让我来给你介绍一个超级...
桌面组件如何弄安卓系统,桌面组... 亲爱的桌面爱好者们,你是否曾梦想过将安卓系统搬到你的电脑桌面上?想象那些流畅的动画、丰富的应用,还有...
安卓13系统介绍视频,新功能与... 亲爱的读者们,你是否对安卓13系统充满好奇?想要一探究竟,却又苦于没有足够的时间去研究?别担心,今天...
车机安卓7.1系统,功能升级与... 你有没有发现,现在的车机系统越来越智能了?尤其是那些搭载了安卓7.1系统的车机,简直就像是个贴心的智...
安卓系统下如何读pdf,And... 你有没有遇到过这种情况:手机里存了一大堆PDF文件,可是怎么也找不到一个能顺畅阅读的工具?别急,今天...
安卓系统全国通用的吗,畅享智能... 你有没有想过,为什么你的手机里装的是安卓系统呢?安卓系统,这个名字听起来是不是有点神秘?今天,就让我...
假苹果手机8安卓系统,颠覆传统... 你有没有想过,如果苹果手机突然变成了安卓系统,会是怎样的景象呢?想象那熟悉的苹果外观,却运行着安卓的...
安卓12.0系统vivo有吗,... 你有没有听说最近安卓系统又升级啦?没错,就是那个让手机焕然一新的安卓12.0系统!那么,咱们国内的手...
核心芯片和安卓系统,探索核心芯... 你知道吗?在科技的世界里,有一对“黄金搭档”正悄悄改变着我们的生活。他们就是——核心芯片和安卓系统。...
如何调安卓系统屏幕颜色,安卓系... 亲爱的手机控们,你是否曾觉得安卓系统的屏幕颜色不够个性,或者是因为长时间盯着屏幕而感到眼睛疲劳?别担...
旧台式电脑安装安卓系统,轻松安... 你那台旧台式电脑是不是已经服役多年,性能逐渐力不从心,却又不忍心让它退役呢?别急,今天就来教你怎么给...
美国要求关闭安卓系统,科技霸权... 美国要求关闭安卓系统:一场技术革新还是政治博弈?在数字化时代,智能手机已经成为我们生活中不可或缺的一...
安卓系统日记本 你有没有发现,手机里的安卓系统日记本,简直就是记录生活点滴的宝藏库呢?想象每天忙碌的生活中,有没有那...
安卓手机广告最少的系统,探索安... 你有没有发现,用安卓手机的时候,广告总是无处不在,让人烦得要命?不过别急,今天我要给你揭秘一个秘密—...