快速排序最差的情况

作者&投稿:象骅 (若有异议请与网页底部的电邮联系)

快速排序算法(free pascal)详解,不要源程序,时间复杂度n(logn);谢了\/...
快速排序法是所有排序方法中速度最快、效率最高的方法。程序如下:var a:array[0..10] of integer;n:integer;procedure qsort(l,r:longint);{r,l表示集合的左右边界,即把第r到第l个数进行排序} var i,j,m:longint;begin m:=a[l];{标准数} i:=l; {I,J为指针} j:=r;repeat...

为什么快速排序先对长度较短的子序列进行排序
大家知道,递归对性能是有一定影响的,QSort函数在其尾部有两次递归操作。如果待排序的序列划分极端不平衡,递归深度将趋近于n,而不是平衡时的log2n,这就不仅仅是速度快慢的问题了。栈的大小是很有限的,每次递归调用都会耗费一定的栈空间,函数的参数越多,每次递归耗费的空间也越多。因此如果能减少...

什么排序的速度(时间复杂度)最快?
而其他算法的最好情况同平均情况大致相同。如果从最坏的情况考虑,快速排序的时间复杂度为O(n2),插入排序和起泡排序虽然同平均情况相同,但系数大约增加一倍,运行速度降低一半,而选择排序、堆排序和归并排序则影响不大。总之,在平均情况下,快速排序最快;在最好情况下,插入排序和起泡排序最快;在最...

为什么快速排序比堆排序快呢?
一般情况下,快速排序效率要高于堆排序。因为堆排序的常数较大(不过也是1~2之间吧)。快速排序的平均时间复杂度是O(1.39nlogn)。一般来说,除非有需要绝对保证不能出现O(n^2)的要求,不使用堆排。堆排序需要有效的随机存取。

归并排序
当时我把快速排序背完了,抓紧时间还顺便背了一下历史,免得晚上听写又不及格。 不像归并排序,快速排序的时间复杂度很难计算。我们可以看到,归并排序的复杂度最坏情况下也是O(nlogn)的,而快速排序的最坏情况是O(n^2)的。如果每一次选的关键字都是当前区间里最大(或最小)的数,那么这样将使得每一次的规模只...

C++快排的问题
C.A.R.Hoare于1962年提出的。显然快速排序可以用递归实现,当然也可以用栈化解递归实现。下面的函数是用递归实现的,有兴趣的朋友可以改成非递归的。快速排序是不稳定的。最理想情况算法时间复杂度O(nlog2n),最坏O(n^2)--[n的平方]=== 功能:堆排序 输入:数组名称(也就是数组首地址)、数...

高分求数据结构(C语言)高手做题!(200悬赏+50追加+20采纳=270分)_百度...
62.快速排序在最坏情况下时间复杂度是O(n2),比( D )的性能差。A)堆排序 B)起泡排序 C)选择排序 D)直接插入排序 63.下列排序算法中一趟结束后未必能选出一个元素放在其最终位置上的算法是(A)。A)快速排序 B)冒泡排序 C)树形选择排序 D)归并排序 64.若需在O(nlogn)...

什么情况下使用快速排序比较快
在分区时两个子分区最平衡时。因为两个子分区大小不可能同时大于n\/2,所以一个分区大小为n\/2的下界,另一个分区大小为n\/2的上界加1时,快速排序的运行速度最快。这时,表达其运行时间的递归式为 T(n) <= 2T(n\/2) + O(n)根据定理 T(n) = if n = 1 , then O(n)if n > 1, ...

3. 对下列关键字序列用快速排序法进行排序时,速度最快的情形是:
所以说第一位的值的位置更靠中间(排序好的)、所以应该是选A、

声音在物体中传播速度的排序由高到低
结论:声音的传播速度在不同介质中有所差异,排序通常为固体>液体>气体(但有例外),具体数值如:在25℃的软木中,速度可达500m\/s,而在煤油中则是1324m\/s,而在真空中声音无法传播,速度为0m\/s。声音的传播速度受介质种类和温度影响,例如,空气在15℃时的速度为340m\/s,而在25℃时增加到346m...

资性18866655639问: 快速排序最差状况 -
牙克石市瑞巴回答: 和支点元素的选择有关系.所选支点元素每次递归后都在最前面或最后面.这样情况就会最差了.我们知道一般的排序.(如冒泡..)在一个数组p[m,n]中排序.都是确定最大或最小,而确定最大值(最小值)要经过n-m-1次比较.而整个过程就差不多是(n-m-1)!次比较.快排中:一次比较可以确定支点元素的位置.若p[m,q,n](q为支点元素).当然确定第一个元素也是要比较(n-m-1)次.但第二个,第三个(第二层)就是(q-m-1)和(n-q-1)次比较.明显q的值若为m或n,快排就没有什么优势了

资性18866655639问: 快速排序法的平均时间复杂度和最坏时间复杂度分别是多少? -
牙克石市瑞巴回答: 快速排序的平均时间复杂度和最坏时间复杂度分别是O(nlgn)、O(n^2). 当排序已经成为基本有序状态时,快速排序退化为O(n^2),一般情况下,排序为指数复杂度. 快速排序最差情况递归调用栈高度O(n),平均情况递归调用栈高度O(logn),而...

资性18866655639问: 快速排序为什么是效率最高的?快速排序效率最差为O(n*n),平均为O(nlogn).1.若果是最坏情况的话岂不是效率很低?2.对比基数排序的线形时间不是基数排... -
牙克石市瑞巴回答:[答案] 别拿最坏的情况和其他排序算法的最好的情况比,况且排序算法本来就和数据的组织形式有关.

资性18866655639问: 快速排序在什么情况下效率最低?线性表元素个数过多or线性表元素已基本有序?为什么? -
牙克石市瑞巴回答: 基本有序的情况,且在排好序时最差. 因为此时快速排序在分区时产生的两个区域分别包含n-1个元素和0个元素.因为每一出现这种不对称划分时花在划分的时间代价为O(n).递归下去花的时间就是O(n的平方).

资性18866655639问: 快速排序算法在什么情况下性能会变的很差 -
牙克石市瑞巴回答: 首先它是一种排序算法,排序算法是为了让无序的数据组合变成有序的数据组合.有序的数据组合最大的优势是在于当你进行数据定位和采用时, 会非常方便,因为这个数据是有序的 从而在代码设计的时候会让你避免很多不必要的麻烦, 因为无序数据你在进行推断数据前后关系的时候会显示很繁琐快速排序是排序中的一种,它在最差情况下和别的排序相差不大 而在最优,一般情况下,会比一般的排序方法更节省时间这里的一般排序是指:起泡,希尔,插入等常规排序方法其实我个人更喜欢插入,不过这对于链表操作更方便,因为容易操作……

资性18866655639问: 快速排序与希尔排序哪个效率更高? -
牙克石市瑞巴回答: 个人认为是快速排序. 快速排序的最差复杂度可能会降为n^2,最快则是nlogn,但是,平均情况下是较快的. 而 希尔排序的最差情况下,复杂度可能会降为n^s 到n^s之间,(1<=s<=2),平均则是nlog^2n.理论上来看,希尔排序可能是效率...

资性18866655639问: 8、快速排序平均情况和最坏情况下的算法时间复杂度分别为:A)平均情况O(nlog(2,n)),最坏情况O(n^2) B)8、快速排序平均情况和最坏情况下的算法时间... -
牙克石市瑞巴回答:[答案] 是A 最坏的情况是当这个列本来就有序的情况,这样的情况是很坏的,达到了N平方的复杂度.

资性18866655639问: 对n个记录的文件进行快速排序,需要多大的辅助存储空间大约为多大? -
牙克石市瑞巴回答: 每趟排序需要一个辅助空间,辅助空间和趟数有关,最好情况是log2 n ,最差的情况是n. 快速排序由C. A. R. Hoare在1960年提出. 它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分...

资性18866655639问: 快速排序平均情况和最坏情况下的算法时间复杂度分别为: 平均情况O(nlog(2,n)),最坏情况O(n^2) 平均情况O -
牙克石市瑞巴回答: 最坏情况就是最多比较转换的次数 平均情况指的是一般比较转换的次数,并不是 (最坏情况+最好情况)/2你好好看看CODE 才能领悟到

资性18866655639问: 快速排序为什么是效率最高的? -
牙克石市瑞巴回答: 基数排序是属于稳定性的排序在某些时候是比其他的比较性排序要快 但是如果看一般情况,数据为随机的,快速排序是效率很高的.


本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网