概述
快速排序思想:冒泡排序的进阶版本,也用到了分治思想和递归
快速排序原理:
①先从队尾开始向前扫描且当low < high时,如果li[high] >li[0],则high–,但如果li[high] < li[0],则将high的值赋值给low,即li[low] = li[high],同时要转换数组扫描的方式,即需要从队首开始向队尾进行扫描了
②同理,当从队首开始向队尾进行扫描时,如果li[low] < li[0],则low++,但如果li[low] > li[0]了,则就需要将low位置的值赋值给high位置,即li[low] = li[high],同时将数组扫描方式换为由队尾向队首进行扫描.
③不断重复①和②,知道low>=high时(其实是low=high),low或high的位置就是该基准数据在数组中的正确索引位置.
l = [0, 5, 13, 26, 20, 15, 65, 41, 51]
def partition_hwq(li, i, j):
povotkey = li[i]
li[0] = povotkey
while i < j:
while i < j and li[j] >= povotkey:
j -= 1
li[i] = li[j]
while i < j and li[i] <= povotkey:
i += 1
li[j] = li[i]
li[i] = li[0]
return i
def qsort(li, i, j):
if i < j:
partition_hwq(li, i, j)
qsort(li, i, partition_hwq(li, i, j)-1)
qsort(li, partition_hwq(li, i, j)+1, j)
def quick_sort(li, n):
qsort(li, 1, n)
quick_sort(l, len(l)-1)
print(l)
最后
以上就是和谐薯片为你收集整理的python实现快速排序的全部内容,希望文章能够帮你解决python实现快速排序所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复