归并排序
1. 算法原理和Python代码
归并(Merge)排序法是将两个(或两个以上)有序表合并成一个新的有序表,即把待排序序列分为若干个子序列,每个子序列是有序的。然后再把有序子序列合并为整体有序序列。
首先用Python实现合并两个有序列表的操作。这个非常简单,只要从比较二个列表的第一个数,谁小就先取谁,取了后就将相应的下标右移一位。然后再进行比较,如果有列表访问结束,那直接将另一个列表的数据依次取出即可。
#coding:utf-8
#合并有序列表
def mergeList(a, b):
c = []
i = 0
j = 0
while i < len(a) and j < len(b):
print "1:",i,j
if a[i] < b[j]:
c.append(a[i])
i += 1
else:
c.append(b[j])
j += 1
while i < len(a):
c.append(a[i])
i += 1