请用python语言写一个快速排序程序
时间: 2023-04-01 11:03:29 浏览: 95
我可以回答这个问题。以下是一个用 Python 语言编写的快速排序程序:
def quick_sort(arr):
if len(arr) <= 1:
return arr
else:
pivot = arr[]
left = []
right = []
for i in range(1, len(arr)):
if arr[i] < pivot:
left.append(arr[i])
else:
right.append(arr[i])
return quick_sort(left) + [pivot] + quick_sort(right)
arr = [3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5]
sorted_arr = quick_sort(arr)
print(sorted_arr)
输出结果为:[1, 1, 2, 3, 3, 4, 5, 5, 5, 6, 9]
相关问题
用python写一个快速排序的程序
下面是一个使用 Python 语言的快速排序的程序:
```
def quick_sort(array):
if len(array) < 2:
return array
else:
pivot = array[0]
less = [i for i in array[1:] if i <= pivot]
greater = [i for i in array[1:] if i > pivot]
return quick_sort(less) + [pivot] + quick_sort(greater)
print(quick_sort([10, 5, 2, 3]))
```
程序的流程是:
1. 如果数组的长度小于 2,那么就直接返回这个数组;
2. 否则,选取数组的第一个元素作为基准值 pivot;
3. 创建两个列表 less 和 greater,分别存储数组中小于等于 pivot 的值和大于 pivot 的值;
4. 对 less 和 greater 分别使用快速排序;
5. 最后,将排好序的 less 和 pivot 和排好序的 greater 合并在一起并返回。
希望这个程序能帮到你!
阅读全文