我是靠谱客的博主 和谐薯片,最近开发中收集的这篇文章主要介绍python实现快速排序,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

快速排序思想:冒泡排序的进阶版本,也用到了分治思想和递归

快速排序原理:

①先从队尾开始向前扫描且当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实现快速排序所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(39)

评论列表共有 0 条评论

立即
投稿
返回
顶部