在冒泡排序,插入排序,选择排序,快速排序中,在最最坏情况下,快速排序的时间复杂为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)
O(n log n)是什么?明天嘉兴市竞赛!!!!!!!!!!!!!
排一下序 好吗?
这个就是时间复杂度 比O(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);