机房360首页
当前位置:首页 » 云开发 » 云计算开发实例:Python3快速排序

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

来源:techweb 作者: 更新时间:2020/12/23 11:46:47

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

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

  步骤为:

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

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

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

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

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

  实例

202012230905

  责任编辑:张华

机房360微信公众号订阅
扫一扫,订阅更多数据中心资讯

本文地址:http://www.jifang360.com/news/20201223/n8037135805.html 网友评论: 阅读次数:
版权声明:凡本站原创文章,未经授权,禁止转载,否则追究法律责任。
相关评论
正在加载评论列表...
评论表单加载中...
  • 我要分享
推荐图片