云计算开发实例:Python3快速排序

人工智能 2022-06-19 08:09www.robotxin.com人工智能专业

快速排序使用分治法(Divide and conquer)策略来把一个序列(list)分为较小和较大的2个子序列,然后递归地排序两个子序列。

步骤为

挑选基准值从数列中挑出一个元素,称为"基准"(pivot);

分割重新排序数列,所有比基准值小的元素摆放在基准前面,所有比基准值大的元素摆在基准后面(与基准值相等的数可以到任何一边)。在这个分割结束之后,对基准值的排序就已经完成;

递归排序子序列递归地将小于基准值元素的子序列和大于基准值元素的子序列排序。

递归到最底部的判断条件是数列的大小是零或一,此时该数列显然已经有序。

选取基准值有数种具体方法,此选取方法对排序的时间性能有决定性影响。

实例

执行以上代码输出结果为

Copyright © 2016-2025 www.robotxin.com 人工智能机器人网 版权所有 Power by