Python归并排序代码
时间: 2023-06-30 13:27:04 浏览: 107
以下是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
```
这段代码中,我们定义了一个`merge_sort`函数来实现归并排序。排序的主循环通过递归地拆分原始数组成为左右两个子序列来进行。每个子序列被递归地排序,直到子序列中只有一个元素。之后,两个已排序的子序列被合并到一个新的有序序列中。合并过程是通过比较左右两个子序列中的元素来进行的。如果左子序列中的元素小于右子序列中的元素,则将左子序列中的元素添加到新序列中,否则将右子序列中的元素添加到新序列中。最后,如果其中一个子序列的元素已经全部添加到新序列中,则将另一个子序列中剩余的元素添加到新序列中。
阅读全文