分治算法快速排序python交换位置
时间: 2023-06-30 14:24:33 浏览: 96
好的,下面是使用分治算法实现快速排序的Python代码,其中采用了交换位置的方式:
```python
def partition(arr, low, high):
pivot = arr[high]
i = low - 1
for j in range(low, high):
if arr[j] <= pivot:
i += 1
arr[i], arr[j] = arr[j], arr[i]
arr[i+1], arr[high] = arr[high], arr[i+1]
return i+1
def quick_sort(arr, low, high):
if low < high:
pi = partition(arr, low, high)
quick_sort(arr, low, pi-1)
quick_sort(arr, pi+1, high)
arr = [10, 7, 8, 9, 1, 5]
n = len(arr)
quick_sort(arr, 0, n-1)
print("排序后的数组:")
for i in range(n):
print(arr[i], end=" ")
```
这里的快速排序算法采用了分治的思想,将数组分为两个子数组,然后分别对子数组进行排序,最后将排好序的子数组合并起来。其中,partition函数用于将数组分为两个子数组,以数组中最后一个元素作为pivot,将小于等于pivot的元素放到左边,大于pivot的元素放到右边,最后返回pivot的位置。quick_sort函数用于对整个数组进行排序,首先调用partition函数将数组分为两个子数组,并分别对子数组进行排序,最后将排好序的子数组合并起来。
阅读全文