时间:2021-05-22
本文实例讲述了Python实现快速排序的方法。分享给大家供大家参考,具体如下:
说起快排的Python实现,首先谈一下,快速排序的思路:
1、取一个参考值放到列表中间,初次排序后,让左侧的值都比他小,右侧的值,都比他大。
2、分别对左侧和右侧的部分递归第1步的操作
实现思路:
编程实现:
#快排的主函数,传入参数为一个列表,左右两端的下标def QuickSort(list,low,high): if high > low: #传入参数,通过Partitions函数,获取k下标值 k = Partitions(list,low,high) #递归排序列表k下标左侧的列表 QuickSort(list,low,k-1) # 递归排序列表k下标右侧的列表 QuickSort(list,k+1,high)def Partitions(list,low,high): left = low right = high #将最左侧的值赋值给参考值k k = list[low] #当left下标,小于right下标的情况下,此时判断二者移动是否相交,若未相交,则一直循环 while left < right : #当left对应的值小于k参考值,就一直向右移动 while list[left] <= k: left += 1 # 当right对应的值大于k参考值,就一直向左移动 while list[right] > k: right = right - 1 #若移动完,二者仍未相遇则交换下标对应的值 if left < right: list[left],list[right] = list[right],list[left] #若移动完,已经相遇,则交换right对应的值和参考值 list[low] = list[right] list[right] = k #返回k值 return rightlist_demo = [6,1,2,7,9,3,4,5,10,8]print(list_demo)QuickSort(list_demo,0,9)print(list_demo)运行结果:
[6, 1, 2, 7, 9, 3, 4, 5, 10, 8]
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
PS:这里再为大家推荐一款关于排序的演示工具供大家参考:
在线动画演示插入/选择/冒泡/归并/希尔/快速排序算法过程工具:
http://tools.jb51.net/aideddesign/paixu_ys
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python数据结构与算法教程》、《Python列表(list)操作技巧总结》、《Python编码操作技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》
希望本文所述对大家Python程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例对比了javascript与Python快速排序实现方法。分享给大家供大家参考。具体如下:js实现方法:functionquicksort(arr){i
本文实例讲述了Python实现桶排序与快速排序算法结合应用的方法。分享给大家供大家参考,具体如下:#-*-coding:UTF-8-*-importnumpya
本文实例讲述了Python实现的插入排序,冒泡排序,快速排序,选择排序算法。分享给大家供大家参考,具体如下:#!/usr/bin/python#coding:u
本文实例讲述了Python实现的数据结构与算法之快速排序。分享给大家供大家参考。具体分析如下:一、概述快速排序(quicksort)是一种分治排序算法。该算法首
本文实例讲述了Python实现的快速排序算法。分享给大家供大家参考,具体如下:快速排序基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有