排序——快速排序

来源:互联网 发布:centos 压缩文件 编辑:程序博客网 时间:2024/04/30 09:29

之前总以为自己已经掌握了快速排序,可是眼高手低,没有好好研究一下它是否是稳定的排序,以及涉及重复元素等问题,最近用到时总是出现小的bug,于是又潜心翻看《算法导论》,经过测试,写出一个正确的快速排序算法。

写正确关键在于paration函数:

(1)如果s<=k<=i,则有a[k]<=m(中枢元素)

(2)如果i+1<=k<=j-1,则有a[i]>m

(3)如果k=e,则有a[k]=x

变量s和e分别表示数组a的起始和结尾元素,i用于跟踪j,直到遇到>中枢元素m的值,此时a[i+1]>m,等待下次(如果存在)遇到<=中枢元素m的知,然后交换。

注意:在paration()函数中选择随机中枢元素时,必须基于当前s值(即在当前s上加上随机值)。

 

关于paration的另一种写法如下:

但是这种写法非常容易出错,必须遵循:

(1)如果取中枢元素m=a[e](即结尾元素),必须保证先做low的自增操作,然后是high的自减操作。

(2)如果取中枢元素m=a[s](即起始元素),必须保证先做high的自减操作,然后是high的自增操作。(代码中所示)

否则将会出现错误。测试案例如3,3,3,1,5,2,4等。

原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 结婚证丢了怎么办离婚手续 结婚证不见了怎么办离婚手续 科目一身份丢了怎么办 考驾照身份证过期了怎么办 酒驾发交通事故致人死亡怎么办 车保险快到期了怎么办 车保险贴掉了怎么办 小车撞凹进去了怎么办 被代位追偿了怎么办 车被别人抵押了怎么办 朋友没驾照借车怎么办 车子被朋友撞了怎么办 电车被交警扣了怎么办 e照扣了12分怎么办 驾驶证被扣33分怎么办 a2驾驶员扣33分怎么办 驾驶证被扣48分怎么办 驾照扣了33分怎么办 车辆被扣36分怎么办 车被朋友借走了怎么办 在中国终身禁驾怎么办 c驾驶证忘年审了怎么办 驾驶证脱审1年多怎么办 驾驶证脱审四个月怎么办 驾照b2过期没审怎么办 a照驾照过期没审怎么办 驾照扣60多分怎么办 无证违章被扣分怎么办 变味的牛奶喝了怎么办 孩子喝了坏牛奶怎么办 孕妇喝了坏牛奶怎么办 驾照过期五年了怎么办 科目一没过之后怎么办? 重庆科目一没过怎么办 科三过了没签字怎么办 驾照过期几天撞死人怎么办 办理过期身份时出错了怎么办 新加坡半年临时驾照过期后怎么办 北京怎么办残摩行驶证 报考驾照三年到期了怎么办 车辆违章扣3分怎么办