设为首页 收藏本站
查看: 902|回复: 0

[经验分享] python排序算法(三)

[复制链接]

尚未签到

发表于 2018-8-11 06:31:40 | 显示全部楼层 |阅读模式
  OK,又到了苦逼的周一了 DSC0000.gif 。快排比较复杂,花了快两天琐碎时间琢磨了感觉还不是很好,据我们老师说当年提出快排的人是在上课突然想起来的,我等只能深深膜拜了 DSC0001.gif
  快速排序是一种具有良好平均性能的排序方法,插入排序将控制当前插入的基准记录插入相对于已经排好序的子表的正确位置,与此不同的是,快速排序将基准记录放在相对于整个列表的正确位置。这个听上去有点闹人,具体的解释我就不巴拉了,可以上网百度。
  以前写快排只实现最基本的功能,完全没考虑到一些边界问题,这些问题当我用python这门语言,当我想用随机数的列表来检验时,一下子暴露了,不过修补程序也是件很快乐的事啊! DSC0002.gif DSC0003.gif
  下面是修改后健壮性比较好的代码,基本不会报错或者陷入死循环:
  ,,
import random  
def QuickSort(x,left,right):
  
counter=0
  
if(left<right):
  
j=right
  
pivot=x[left]
  
i=left+1
  
while(i<=j):
  
while(x<=pivot and i<right):
  
i+=1
  
counter+=1
  
while(x[j]>pivot and j>left):
  
j-=1
  
counter+=1
  
if(i<j):
  
InterChange(x,i,j)
  
counter+=1
  
if(i==j):
  
break
  
InterChange(x,left,j)
  
counter+=1
  
if(j-left>1):
  
counter+=QuickSort(x,left,j-1)
  
if(right-j>1):
  
counter+=QuickSort(x,j+1,right)
  
return counter
  
def InterChange(x,i,j):
  
temp=x
  
x=x[j]
  
x[j]=temp
  
x=[]
  
for a in range(1000):
  
x.append(random.randint(1,1000))
  
#x=[27,85,69,99,97,49,22,64,7,24,10,13,73,99,95,12,89,83,54]
  
#for a in x:
  
#print(a)
  
print('*********')
  
for a in x:
  
if(a>x[len(x)-1]):
  
InterChange(x,x.index(a),len(x)-1)
  
counter=QuickSort(x,0,len(x)-1)
  
for a in x:
  
print(a)
  
print(counter)
  这个程序中我counter计算应该不是很准确,主要精力不是放在上面了。整个过程可以用修好一个bug冒出一个bug来形容。其实主要的问题还是由于大量随机数会产生相同的数导致的……
  34、35行我注释掉了,当时其实程序大部分时候已经能跑成功了,当排序的数的单位设置为百时,但是运行十次会出一次错。为了调这个bug,我只好把排序的数设置为20,然后运行了几十遍之后终于得到这行宝贵的数据,对于这个bug,读者可以把第9行和第12行and后面的判断去掉体会一下。
  第9行和第12行本应该对称,但是9行多了个=号是因为有个潜在的死循环问题,主要是由相同的数引起的,比如这样的排列10,10,10,其中left指向第一个10,i指向第二个,j指向第3个,这样会陷入死循环出不去。但加了=号也导致了下面的问题。
  第8行一开始是没有=号的,但是这个会导致一个排序不彻底的bug,这个的话可以以x=[1,3,9,7,12,23,4,16,20],也就是我之前一直用的例子体会下。至于第18行和第19行又额外加了个i==j的判断是防止它若x=x[j]=x[right],x[i+1]会越界的错这个问题也是用大规模随机数找到的。
  至于38—40行在开始把列表中最大数放到末尾,也是出于避免一些边界问题的考虑。
  现在的程序已经很稳定了,可以经得住随机数的考验,运行下来counter分布在10000—15000之间,但是偶尔(几十次会有一次)也会很高,达到100000的水平,这是因为快排的最坏复杂度是o(n*n)的原因。明天可能还要研究研究快排优化的问题,下面把这个程序最基本的部分给出来方便读者自己修改,基本程序本身是有bug的,读者可以根据需要自行调整下:
def QuickSort(x,left,right):  
counter=0
  
if(left<right):
  
j=right
  
pivot=x[left]
  
i=left+1
  
while(i<=j):
  
while(x<pivot):
  
i+=1
  
while(x[j]>pivot):
  
j-=1
  
if(i<j):
  
InterChange(x,i,j)
  
InterChange(x,left,j)
  
QuickSort(x,left,j-1)
  
QuickSort(x,j+1,right)
  
def InterChange(x,i,j):
  
temp=x
  
x=x[j]
  
x[j]=temp
  
x=[1,3,9,7,12,23,4,16,20]
  
print('*********')
  
for a in x:
  
if(a>x[len(x)-1]):
  
InterChange(x,x.index(a),len(x)-1)
  
QuickSort(x,0,len(x)-1)
  
for a in x:
  
print(a)
  这个基本程序的bug是不能有相同的数,否则会陷入死循环的哦~~ DSC0004.gif

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-549794-1-1.html 上篇帖子: python22期自动化-Day1 下篇帖子: 大家好啊=2001 用python计算
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表