时间:2021-05-22
本文实例讲述了Python快速查找算法的应用,分享给大家供大家参考。
具体实现方法如下:
import randomdef partition(list_object,start,end): random_choice = start #random.choice(range(start,end+1)) #把这里的start改成random()效率会更高些 x = list_object[random_choice] i = start j = end while True: while list_object[i] < x and i < end: i += 1 while list_object[j] > x: j -= 1 if i >= j: break list_object[i],list_object[j] = list_object[j],list_object[i] print list_object #list_object[random_choice] = list_object[j] #list_object[j] = random_choice return jdef quick_sort(list_object,start,end): if start < end: temp = partition(list_object,start,end) quick_sort(list_object,start,temp-1) quick_sort(list_object,temp + 1 ,end) a_list = [69,65,90,37,92,6,28,54]quick_sort(a_list,0,7)print a_list程序测试环境为Python2.7.6
输出结果如下:
[54, 65, 28, 37, 6, 69, 92, 90][6, 37, 28, 54, 65, 69, 92, 90][6, 37, 28, 54, 65, 69, 92, 90][6, 28, 37, 54, 65, 69, 92, 90][6, 28, 37, 54, 65, 69, 90, 92][6, 28, 37, 54, 65, 69, 90, 92]希望本文所述对大家的Python程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了Java实现的快速查找算法。分享给大家供大家参考,具体如下:快速查找算法,可以根据想要找的是第几个大的数,每次循环都能固定下来一个数在数组完整排完
本文实例讲述了Python有序查找算法之二分法。分享给大家供大家参考,具体如下:二分法是一种快速查找的方法,时间复杂度低,逻辑简单易懂,总的来说就是不断的除以2
iPhone如何快速查找手机中的视频?对于现在手机照相如此普遍,我们随手拍的相片不计其数,用传统的方法查找花时间又话眼力,到底iPhone如何快速查找手机中的视
我们在使用过程中想查找一些大型的文件时,怎么样才能避免一个个找的麻烦呢?今天小编就来教大家如何快速查找MAC中的大型文件吧。 如何快速查找大型文件: -
本文实例讲述了Python实现桶排序与快速排序算法结合应用的方法。分享给大家供大家参考,具体如下:#-*-coding:UTF-8-*-importnumpya