用python写递归排序
时间: 2023-03-19 22:21:28 浏览: 125
当然可以,以下是使用Python编写递归排序的示例代码:
```python
def merge_sort(arr):
if len(arr) > 1:
mid = len(arr) // 2
left_half = arr[:mid]
right_half = arr[mid:]
# 递归地将左右两半分别排序
merge_sort(left_half)
merge_sort(right_half)
# 将两个已排序的子数组合并为一个新数组
i = j = k = 0
while i < len(left_half) and j < len(right_half):
if left_half[i] < right_half[j]:
arr[k] = left_half[i]
i += 1
else:
arr[k] = right_half[j]
j += 1
k += 1
# 将剩余的元素拼接到数组末尾
while i < len(left_half):
arr[k] = left_half[i]
i += 1
k += 1
while j < len(right_half):
arr[k] = right_half[j]
j += 1
k += 1
return arr
```
以上是基于归并排序算法的Python代码示例,它将一个数组作为输入参数,并通过递归将其排序,最后返回已排序的数组。这个代码中,将原数组分成两个子数组,递归地对每个子数组进行排序,然后将它们合并到一起以得到最终的已排序数组。
阅读全文