def sort1(arr):
"""
思路:
以arr[0]为pivot
以arr长度小于等于1为边界,返回arr
分别将小于pivot、等于pivot、大于pivot的分类
递归处理两边的分类,将结果组合返回
:param arr:
:return:
"""
if len(arr) <= 1:
return arr
pivot = arr[0]
left = [x for x in arr if x < pivot]
middle = [x for x in arr if x == pivot]
right = [x for x in arr if x > pivot]
return sort1(right) + middle + sort1(left)
def sort2(arr, arr_l, arr_r):
"""
思路:
以arr[arr_r]为pivot
以arr长度小于等于1为边界,直接返回
左游标从arr_l到arr_r移动,当arr[左游标]<=pivot时进行处理:
if arr[左游标]<=arr[r]:
if 左游标 == arr_r:
递归处理 arr_l到arr_r-1
else:
右游标从arr_r-1到左游标移动:
if 右游标>左游标 and arr[右游标]>pivot:
交换arr[左游标] arr[右游标]
跳出右游标的循环
elif 右游标 == 左游标:
交换arr[右游标] pivot
递归处理 arr_l到(右游标-1)
递归处理 (右游标+1)到arr_r
:param arr:
:param arr_l:
:param arr_r:
:return:
"""
if len(arr) <= 1:
return
for left in range(arr_l, arr_r+1):
if arr[left] <= arr[arr_r]:
if left == arr_r:
sort2(arr, arr_l, arr_r-1)
else:
for right in range(arr_r-1, left-1, -1):
if right > left and arr[right] > arr[arr_r]:
arr[right], arr[left] = arr[left], arr[right]
break
elif right == left:
arr[right], arr[arr_r] = arr[arr_r], arr[right]
sort2(arr, arr_l, right-1)
sort2(arr, right+1, arr_r)
return
def sort(arr, method=2):
if method == 1:
return sort1(arr)
elif method == 2:
sort2(arr, 0, len(arr)-1)
return arr
if __name__ == "__main__":
l = [5, 2, 7, 8, 6, 1, 4, 9, 10, 1, 2, 3, 4]
print(sort(l))
快速排序的python实现
原创
©著作权归作者所有:来自51CTO博客作者newidin51的原创作品,请联系作者获取转载授权,否则将追究法律责任
上一篇:归并排序的python实现
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
Python实现的快速排序
Python实现的快速排序
python -
python实现【快速排序】(QuickSort)
python实现【快速排序】(QuickSort)算法原理及介绍快速排序的基本思想t)分为两个子串(sub-lists)。具体算法描
快速排序 排序算法 算法 python 递归 -
快速排序 python 实现 python快速排序原理
快速排序,简称快排,基本上被认为是相同数量级的所有排序算法中,平均性能最好的。今天就学习一下如何实现,希望对你的学习或工作有参考价值原理:对于给定的记录,选择一个基准数(为了方便通常选择第一个数),通过一趟排序后,将原序列分为两部分,使得前面的比后面的小,然后再依次对前后进行拆分进行快速排序,递归该过程,直到序列中所有记录均有序。这是典型的分治思想,或者叫分治法,把问题分为一个个的小部分来分别解决
快速排序 python 实现 python 快速排序 python快速排序 实现快速排序的算法 归并排序验证性实验