数据结构和算法——排序算法的比较和排序综测测验

目录

排序算法的比较

排序综合测验

快又稳定

元素错位

有序排序

排序结果


排序算法的比较

排序方法平均时间复杂度最坏情况下时间复杂度额外空间复杂度稳定性
简单选择排序O(N^2)O(N^2)O(1)不稳定
冒泡排序O(N^2)O(N^2)O(1)稳定
直接插入排序O(N^2)O(N^2)O(1)稳定
希尔排序O(N^d)O(N^2)O(1)不稳定
堆排序O(NlogN)O(NlogN)O(1)不稳定
快速排序O(NlogN)O(N^2)O(logN)不稳定
归并排序O(NlogN)O(NlogN)O(N)稳定
基数排序O(P(N+B))O(P(N+B))O(N+B)稳定

排序综合测验

快又稳定

请选择下面四种排序算法中最快又是稳定的排序算法:

A. 希尔排序 B. 堆排序 C. 归并排序 D. 快速排序

选择C:归并排序

归并排序是一种分治算法,它将待排序的数组不断地分割成更小的子数组,然后将这些子数组合并成有序的数组。归并排序的时间复杂度是O(NlogN),其中N是待排序数组的长度。它是一种稳定的排序算法,即相等元素的相对顺序在排序后不会改变。

希尔排序、堆排序和快速排序都是不稳定的排序算法。

  1. 希尔排序(Shell Sort): 希尔排序是插入排序的一种改进版本。它通过将待排序的数组分割成若干个子序列,对这些子序列进行插入排序,然后逐渐缩小子序列的长度,直到整个数组有序。在希尔排序的过程中,相等元素之间的相对顺序可能会发生改变,因为每一趟排序涉及到不相邻的元素之间的交换。

  2. 堆排序(Heap Sort): 堆排序是利用堆这种数据结构来进行排序的算法。在堆排序中,首先将待排序的数组构建成一个最大堆(或最小堆),然后逐步取出堆顶元素(最大值或最小值),并进行调整维持堆的性质。由于堆的构建和调整过程涉及到交换元素,相等元素在交换过程中可能会改变其相对顺序。

  3. 快速排序(Quick Sort): 快速排序也是一种分治算法。它选择一个基准元素,将数组分成两个子数组,一个子数组的元素都比基准元素小,另一个子数组的元素都比基准元素大,然后递归地对这两个子数组进行排序。在快速排序的过程中,相等元素的相对顺序可能会发生改变,因为在分区的过程中,相等元素可能会被分到不同的子数组中。

在稳定的排序算法中,相等元素的相对顺序保持不变。而在这些不稳定的排序算法中,由于涉及到元素交换和分区操作,相等元素的相对顺序可能会发生变化。

 

元素错位

下列排序算法中,哪种算法可能出现:在最后一趟开始之前,所有的元素都不在其最终的位置上

A. 堆排序 B. 插入排序 C. 冒泡排序 D. 快速排序

选择:B.插入排序

插入排序是一种稳定的排序算法,它通过构建有序序列,对于未排序的元素,逐个插入到已排序序列中的适当位置。在每一趟排序过程中,未排序的元素会逐渐移动到其最终的位置,但在最后一趟开始之前,所有的元素可能都还没有在其最终的位置上。例如:插入最后一个元素之前,需要将每个元素都错位,将每一个元素都往后移一位。

 

有序排序

当待排序列已经基本有序时,下面哪个排序算法效率最差

A. 快速排序 B. 直接插入 C. 选择排序 D. 堆排序

选择C:选择排序

选择排序的时间复杂度也是O(N^2),其中N是待排序序列的长度。选择排序的主要思想是每次从未排序的部分选择最小(或最大)的元素,并放置到已排序部分的末尾。在待排序列基本有序的情况下,选择排序的效率会非常低。即使序列已经基本有序,选择排序仍然需要花费大量的时间来查找最小元素的位置,然后进行交换。因此,选择排序在待排序序列基本有序的情况下,效率会明显下降。

看其他选项:

  • A. 快速排序:在平均情况下,其时间复杂度为O(NlogN)。当待排序序列基本有序时,快速排序的性能仍然较好。虽然在某些特殊情况下可能有较差的性能(如已经完全有序的序列),但其平均性能较好,通常情况下效率较高。
  • B. 直接插入排序:在待排序序列基本有序的情况下,只有少数几个元素位置不正确,插入排序只需要对这几个元素进行少量的比较和交换即可。
  • D. 堆排序:堆排序的时间复杂度为O(NlogN),在待排序序列基本有序的情况下,由于需要构建堆结构,其性能会略有下降,但相对于直接插入排序和选择排序,堆排序在效率上仍然相对较好。

排序结果

数据序列(3,2,4,9,8,11,6,20)只能是下列哪种排序算法的两趟排序结果

A. 冒泡排序 B. 插入排序 C. 选择排序 D. 快速排序

选择D :快速排序


end


学习自:MOOC数据结构——陈越、何钦铭

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/48184.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Springboot之把外部依赖包纳入Spring容器管理的两种方式

前言 在Spring boot项目中,凡是标记有Component、Controller、Service、Configuration、Bean等注解的类,Spring boot都会在容器启动的时候,自动创建bean并纳入到Spring容器中进行管理,这样就可以使用Autowired等注解,…

关注这些问题,助你找到理想工作

导语:在寻找理想工作的过程中,有一些关键问题需要我们特别关注。了解并回答这些问题将有助于我们更好地定位自己,并找到符合自身需求和目标的职位。本文将介绍一些在找工作时需要关注的重要问题。 个人定位:首先,我们…

Vue源码学习 - 异步更新队列 和 nextTick原理

目录 前言一、Vue异步更新队列二、nextTick 用法三、原理分析四、nextTick 源码解析1)环境判断2)nextTick() 五、补充 前言 在我们使用Vue的过程中,基本大部分的 watcher 更新都需要经过 异步更新 的处理。而 nextTick 则是异步更新的核心。…

视频剪辑矩阵分发系统Unable to load FFProbe报错技术处理?

问题一 报错处理 对于视频剪辑矩阵分发系统中出现的“Unable to load FFProbe”报错问题,可以采取以下技术处理措施进行解决。 1.检查系统中是否正确安装了FFProbe工具,并确保其路径正确配置。 2.检查系统环境变量是否正确设置,包括FFPr…

CSS鼠标样式(cursor)

CSS cursor 属性值 属性值示意图描述auto默认值,由浏览器根据当前上下文确定要显示的光标样式default 默认光标,不考虑上下文,通常是一个箭头none不显示光标initial将此属性设置为其默认值inherit从父元素基础 cursor 属性的值context-menu…

【深度解析】蓝牙室内定位方案优势介绍

万物互联时代,数据的价值进一步凸显,在海量数据中,位置数据成为万物互联产业中的基础坐标。室内空间结构越来越复杂,人们对位置的实时性和精确度要求不断提高,室内定位的需求也空前高涨。卫星信号对障碍物的穿透性较弱…

git使用教程

一 创建环境 参考 Git 安装配置 | 菜鸟教程 (runoob.com)https://www.runoob.com/git/git-install-setup.html 1.1 配置 $ git config --global user.name "runoob" $ git config --global user.email test@runoob.com 1.2 创建一个新文件夹 在新的文件夹执行(…

额外题目第1天|1365 941 1207 283 189 724 34 922 35 24

1365 暴力解法也能过 class Solution { public:vector<int> smallerNumbersThanCurrent(vector<int>& nums) {vector<int> result(nums.size(), 0);for (int i0; i<nums.size(); i) {int count 0;for (int j0; j<nums.size(); j) {if (nums[j]<…

无涯教程-jQuery - jQuery.getScript( url, callback )方法函数

jQuery.getScript(url&#xff0c;[callback])方法使用HTTP GET请求加载并执行JavaScript文件。 该方法返回XMLHttpRequest对象。 jQuery.getScript( url, [callback] ) - 语法 $.getScript( url, [callback] ) 这是此方法使用的所有参数的描述- url - 包含请求…

Educational Codeforces Round 152 (Rated for Div. 2) B. Monsters

很早想到%K排序,但是就是WA2,心态崩了,昨天晚上差点睡不着觉吐了,感觉自己好笨啊啊啊, 言归正传, 按照正常的思路,样例是可以过的,但是AC不了,例如给出样例3 3 3 1 2 经过自己模拟应该输出1 3 2 ,但是只会输出1 2 3 ,知道症结所在debug,0的先输出,之后输出k-1,k-2…但是怎么实现…

物联网的通信协议

物联网的通信协议 目录 物联网的通信协议一、UART串口通信1.1 串口通信1.2 异步收发1.3 波特率1.4 串口通信协议的数据帧1.5 优缺点1.5.1 优点1.5.2 缺点 二、I^2^C2.1 I^2^C2.2 I^2^C2.3 数据有效性2.4 起始条件S和停止条件P2.5 数据格式2.6 协议数据单元PDU2.7 优缺点2.7.1 优…

Python教程三:Python基本概念

1、Python基本语法 Python中严格区分大小写Python中每一行就是一条语句&#xff0c;每条语句以换行结束每一行语句不建议过长&#xff08;一般不建议超过80个字符&#xff09;一条语句可以多行编写&#xff0c;语句后加\结尾Python是缩进严格的语言&#xff0c;所以在Python中…

RNN架构解析——注意力机制

目录 注意力机制实现 注意力机制 实现

导出为PDF加封面且分页处理dom元素分割

文章目录 正常展示页面导出后效果代码 正常展示页面 导出后效果 代码 组件内 <template><div><div><div class"content" id"content" style"padding: 0px 20px"><div class"item"><divstyle"…

栈粉碎原理分析

栈粉碎原理分析 源代码如下 #include <stdio.h>void function(int a, int b) {char buffer[12];gets(buffer);//long* ret (long *) ((long)buffer28);//*ret *ret 7;return; }void main() {int x;x 0;function(1,2);x 1;printf("%d\n",x); } 由解注释前…

windows C++多线程同步<3>-互斥量

windows C多线程同步&#xff1c;3&#xff1e;-互斥量 概念&#xff0c;如下图&#xff1a; 另外就是互斥对象谁拥有&#xff0c;谁释放 那么一个线程允许多次获取互斥对象吗&#xff1f; 答案是允许&#xff0c;但是申请多次就要释放多次&#xff0c;否则其他线程获取不到互…

「分享」Word文档被锁定无法编辑怎么办?4种方法解决

有没有遇到这种情况&#xff1f;打开Word文档后&#xff0c;发现文档被锁定了&#xff0c;无法输入内容&#xff0c;也无法修改&#xff0c;这很大可能是Word文档被设置了“限制编辑”。 如果Word文档被设置了“限制编辑”&#xff0c;而我们又需要编辑文档&#xff0c;可以用…

等分切割图片的方法

在做数据集的过程中&#xff0c;有时候需要将大图进行切分成小图片&#xff0c;一方面是为了满足训练需要&#xff0c;一方面是为了扩增数据集。 如下图的尺寸为5472x3648,但是我用不着这么大的图片&#xff0c;需要将图9等分 市面上也有等分切割图片的软件或者网站&#xff…

tensorRT多batch动态推理

tensorRT的多batch推理&#xff0c;导出的onnx模型必须是动态batch&#xff0c;只需在导出的时候&#xff0c;设置一个dynamic_axis参数即可。 torch.onnx.export(hybrik_model, dummy_input, "./best_model.onnx", verboseTrue, input_namesinput_names, \output_…

19 QListWidget控件

Tips: 对于列表式数据可以使用QStringList进行左移一块输入。 代码&#xff1a; //listWidget使用 // QListWidgetItem * item new QListWidgetItem("锄禾日当午"); // QListWidgetItem * item2 new QListWidgetItem("汗滴禾下土"); // ui->…