数据结构题目收录(二十三)
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

相关内容

热门资讯

安卓系统的几大组件,组件架构与... 你有没有发现,你的安卓手机里藏着许多神奇的“小精灵”呢?它们默默无闻地工作,让你的手机变得如此强大和...
安卓系统关闭app流量,轻松关... 手机里的APP们是不是有时候让你觉得流量消耗得有点儿太快了呢?别急,今天就来教你几招,让你的安卓手机...
安卓系统无尽之海,安卓系统中的... 安卓系统,无尽之海中的航行者想象你正站在一望无际的海洋边,海风轻拂,波光粼粼。这片海洋,深邃而神秘,...
苹果系统用安卓主题,安卓主题完... 你有没有想过,把苹果系统的简洁优雅和安卓的丰富个性结合起来呢?想象你的iPhone界面突然变得五彩斑...
ios系统和安卓系统的体验,系... 你有没有发现,现在手机市场上两大巨头——iOS系统和安卓系统,就像是一对双胞胎,各有各的特色,让人挑...
安卓刷机Linux系统,深度解... 你有没有想过,你的安卓手机其实可以变身成一个强大的Linux系统?没错,就是那个让无数程序员为之疯狂...
安卓系统卫士那个好,哪款更胜一... 手机里的安卓系统卫士,就像是我们的私人保镖,时刻守护着我们的手机安全。那么,这么多卫士中,哪个才是最...
安卓手机互换苹果系统,跨界体验... 你有没有想过,把安卓手机换成苹果系统,会是怎样的体验呢?想象你的手机瞬间变身,从安卓的海洋跳进了苹果...
共享系统推荐安卓游戏,共享系统... 你有没有发现,最近手机里的游戏推荐越来越贴心了?没错,就是那个神奇的共享系统,它就像你的私人游戏顾问...
新疆安卓系统广告机,智能展示新... 新疆安卓系统广告机:数字时代的弄潮儿在数字化浪潮席卷全球的今天,智能手机已成为我们生活中不可或缺的一...
tissot怎么配对安卓系统,... 你有没有想过,一块手表不仅仅是一件饰品,更是一种时尚的宣言呢?Tissot,这个瑞士手表品牌,以其优...
苹果系统真的不如安卓,苹果系统... 你有没有想过,为什么苹果系统总是被捧得那么高,而安卓系统却总是被说成“不如”呢?今天,咱们就来聊聊这...
安卓系统短信横幅关闭,享受清爽... 你是不是也和我一样,最近发现安卓手机的短信横幅功能有点烦人呢?每次收到短信,屏幕上就会飘来一条横幅,...
手机刷安卓11系统,系统革新与... 你有没有发现,最近你的手机好像变得有点不一样了?没错,就是那个一直默默陪伴你的安卓系统,它悄悄地升级...
安卓系统 漂移游戏下载,速度与... 你有没有想过,在手机上玩一款能让你心跳加速、手忙脚乱的游戏?今天,就让我带你走进安卓系统中的神秘世界...
安卓4修改系统语言,轻松切换多... 你有没有想过,手机里的语言设置竟然也能成为个性展示的小细节呢?没错,就是那个看似不起眼,实则能让你瞬...
安卓版pc端系统,跨越平台界限... 你有没有想过,你的安卓手机里的应用,竟然可以在电脑上无缝运行?没错,这就是安卓版PC端系统的魅力所在...
安卓7车机系统,科技与安全的完... 你有没有发现,现在的汽车越来越智能了?没错,我说的就是那些内置了安卓7车机系统的家伙们。想象当你坐在...
王者荣耀安卓系统区别,深度揭秘... 你有没有发现,玩王者荣耀的时候,安卓系统的手机和苹果系统的手机,感觉就像是两个不同的世界呢?今天,就...
盒子电视安卓9系统,畅享智能新... 亲爱的读者们,你是否曾为拥有一台功能强大、系统流畅的电视而心动?今天,我要给你介绍一款特别受欢迎的盒...