以下排序算法最坏情况下时间复杂度最低的是 A.冒泡排序 B.插入 C.选择 D.快排

如题所述

冒泡排序,插入排序,选择排序,快速排序中,在最最坏情况下,快速排序的时间复杂为O(n2) ,插入排序O(n2),选择排序O(n2),冒泡排序O(n2)。所以ABCD时间复杂度是一样的。

知识拓展:

快速排序算法中,最为关键的就是选取一个基值,将数组分为大于基值以及小于基值两部分,并返回基值所以在位置以利用于递归划分。

对数组a,设需要划分的其中一段为a[p]~a[r],我们期待的结果是得到一个q,其中p<=q<=r,使得a[p]~a[q-1]<=a[q]<=a[q+1]~a[r],这个时候原先的一段数组被分成了三部分。

首先,设基值为这段数组的最后一个元素a[r],我们希望最后得到的结果是a[r]现在对应的值在算法结束后可以排在比他大和小的两部分的中间爱。

然后令i=p-1; j=p,当发现有a[j]>x时,j继续前进,不需要任何移动。当发现a[j]<=x时,我们需要将这个元素放到小于基值的一边,于是将i自加1,并交换此时a[i],与a[j]的元素,然后j自加1。这个时候i指向的是比基值小的那段数据的最后一个元素,j指向的是第一个还没有判断的剩余元素。

上面一步不断循环直到j指向了r,此时只剩下r没有和基值判断了,而a[r]本来就是基值,而除了a[r]以外,a[p]~a[i]是小于基值的部分,a[i+1]~a[r-1]是大于基值的部分,所以此时只需交换a[i+1]和a[r]即可。

由于对数组a从头到尾扫描一次就可以得到结果,因此这一部分算法复杂度为o(n)

温馨提示:内容为网友见解,仅供参考
第1个回答  2012-09-21
1.选择排序:不稳定,时间复杂度 O(n^2)
选择排序的基本思想是对待排序的记录序列进行n-1遍的处理,第i遍处理是将L[i..n]中最小者与L[i]交换位置。这样,经过i遍处理之后,前i个记录的位置已经是正确的了。
2.插入排序:稳定,时间复杂度 O(n^2)
插入排序的基本思想是,经过i-1遍处理后,L[1..i-1]己排好序。第i遍处理仅将L[i]插入L[1..i-1]的适当位置,使得L[1..i] 又是排好序的序列。要达到这个目的,我们可以用顺序比较的方法。首先比较L[i]和L[i-1],如果L[i-1]≤ L[i],则L[1..i]已排好序,第i遍处理就结束了;否则交换L[i]与L[i-1]的位置,继续比较L[i-1]和L[i-2],直到找到某一个位置j(1≤j≤i-1),使得L[j] ≤L[j+1]时为止。图1演示了对4个元素进行插入排序的过程,共需要(a),(b),(c)三次插入。
3.冒泡排序:稳定,时间复杂度 O(n^2)
冒泡排序方法是最简单的排序方法。这种方法的基本思想是,将待排序的元素看作是竖着排列的“气泡”,较小的元素比较轻,从而要往上浮。在冒泡排序算法中我们要对这个“气泡”序列处理若干遍。所谓一遍处理,就是自底向上检查一遍这个序列,并时刻注意两个相邻的元素的顺序是否正确。如果发现两个相邻元素的顺序不对,即“轻”的元素在下面,就交换它们的位置。显然,处理一遍之后,“最轻”的元素就浮到了最高位置;处理二遍之后,“次轻”的元素就浮到了次高位置。在作第二遍处理时,由于最高位置上的元素已是“最轻”元素,所以不必检查。一般地,第i遍处理时,不必检查第i高位置以上的元素,因为经过前面i-1遍的处理,它们已正确地排好序。
4.堆排序:不稳定,时间复杂度 O(nlog n)
堆排序是一种树形选择排序,在排序过程中,将A[n]看成是完全二叉树的顺序存储结构,利用完全二叉树中双亲结点和孩子结点之间的内在关系来选择最小的元素。
5.归并排序:稳定,时间复杂度 O(nlog n)
设有两个有序(升序)序列存储在同一数组中相邻的位置上,不妨设为A[l..m],A[m+1..h],将它们归并为一个有序数列,并存储在A[l..h]。
6.快速排序:不稳定,时间复杂度 最理想 O(nlogn) 最差时间O(n^2)
快速排序是对冒泡排序的一种本质改进。它的基本思想是通过一趟扫描后,使得排序序列的长度能大幅度地减少。在冒泡排序中,一次扫描只能确保最大数值的数移到正确位置,而待排序序列的长度可能只减少1。快速排序通过一趟扫描,就能确保某个数(以它为基准点吧)的左边各数都比它小,右边各数都比它大。然后又用同样的方法处理它左右两边的数,直到基准点的左右只有一个元素为止。

几种排序的时间复杂度,可以参考一下追问

O(n log n)是什么?明天嘉兴市竞赛!!!!!!!!!!!!!
排一下序 好吗?

追答

这个就是时间复杂度 比O(n^2)要低

本回答被提问者和网友采纳
第2个回答  2019-03-31
这几个的最坏情况下的时间复杂度都是一样的,一定要比较的话快排比较快,但冒泡排序比较稳定,最坏的话都是一样的
第3个回答  2012-09-21
显然都一样,如果论平均时间就是快排最快O(nlogn),其余的都是O(n^2),但快排最坏时间也是O(n^2)
第4个回答  2012-09-21
最坏的情况下好像都是n^2吧。

以下排序算法最坏情况下时间复杂度最低的是 A.冒泡排序 B.插入 C...
在冒泡排序,插入排序,选择排序,快速排序中,在最最坏情况下,快速排序的时间复杂为O(n2) ,插入排序O(n2),选择排序O(n2),冒泡排序O(n2)。所以ABCD时间复杂度是一样的。知识拓展:在快速排序算法中,最为关键的就是选取一个基值,将数组分为大于基值以及小于基值两部分,并返回基值所以在位置...

...度最小的是()A.冒泡排序 B.快速排序 C.插入排序D.堆排序
答案是D,堆排序。选项中的四种排序方法的最坏时间复杂度、最好时间复杂度 、平均时间复杂度分别为:A、冒泡排序: O(n2) 、O(n) 、O(n2)。B、快速排序: O(n2) 、O(nlog2n)、 O(nlog2n)。C、插入排序: O(n2)、 O(n) 、O(n2)。D、堆排序: O(nlog2n)、 O(nlog2n)、 ...

下列各排序法中,最坏情况下的时间复杂度最低的是( )。
【答案】:C 堆排序最坏情况时间下的时间复杂度为O(nlog2n);希尔排序最坏情况时间下的时间复杂度为O(n1.5);快速排序、冒泡排序最坏情况时间下的时间复杂度为O(n2)。故本题答案为C选项。

计算机二级考试《公共基础》100题
1、 对长度为n的线性表排序,在最坏情况下,比较次数不是n(n-1)\/2的排序方法是 A) 快速排序 B) 冒泡排序 C) 直接插入排序 √D) 堆排序 2、下列关于栈的叙述正确的是 A) 栈按""先进先出""组织数据 √B) 栈按""先进后出""组织数据 C) 只能在栈底插入数据 D) 不能删除数据 3、算法的空间复杂度...

全国计算机二级考试模拟练习题(1)
D) 算法的时间复杂度与算法程序编制者的水平有关 2、下列各排序法中,最坏情况下的时间复杂度最低的是()。A) 希尔排序 B) 快速排序 C) 堆排序 D) 冒泡排序 3、设栈的存储空间为S(1:50),初始状态为top=51。现经过一系列正常的入栈与退栈操作后 则栈中的元素个数为()。A) 1...

各种排序算法最好和最坏情况比较
最坏情况下比较次数最少的为D)堆排序:A)冒泡排序 需要比较O(n^2)次(n(n - 1)\/2次),即序列逆序的情况 B)简单选择排序,无论是否最坏都需要O(n^2)次(n(n - 1)\/2次)C)直接插入排序,最坏情况需要比较O(n^2)次(n(n - 1)\/2次)D)堆排序,无论是否最坏比较O(nlog2n...

以下哪个排序算法的最坏时间复杂度是O(nlogn)?
对于排序算法,平均时间复杂度 插入排序 O(n^2)冒泡排序 O(n^2)选择排序 O(n^2)快速排序 O(n log n)堆排序 O(n log n)归并排序 O(n log n)基数排序 O(n)希尔排序 O(n^1.25)有一个时间复杂度的排列顺序,依次为 Ο(1)<Ο(log2n)<Ο(n)<Ο(nlog2n)<Ο(n2)<Ο(n3)...

noip2009初赛答案
A) 2n + 1 B) 2n - 1 C) n - 1 D) n + 1 【分析】选择D 考二叉树的性质:N0=N2+1 即叶子节点比二叉节点数多一个。15、 快速排序最坏情况下的算法复杂度为: A) O (log2n) B) O (n) C) O (nlog2n) D) O (n2) 【分析】选择D 最坏情况时间复杂度,每次选择的数都是最靠边的数...

《数据结构》第08章在线测试
D、简单选择排序 E、直接插入排序 3、下列排序方法中,空间复杂度为O(1)的排序方法有___ACD___。A、堆排序 B、快速排序 C、直接插入排序 D、冒泡排序 4、下列排序方法中,在最坏情况下算法的时间复杂度为O(n^2)的有_BCD___。A、堆排序 B、快速排序 C、希尔排序 D、冒泡排序 5、...

直接插入排序、快速排序、冒泡排序最坏的情况下那种排序更好
最好的当然是快排,时间复杂度只有O(nlogn);最坏事都是O(n^2);另外,对于特殊数据,冒泡可以优化到O(n);

相似回答