mirror of
https://github.com/TheAlgorithms/Python.git
synced 2024-11-30 16:31:08 +00:00
b6cc37d461
* mergesort added * added doctest
46 lines
863 B
Python
46 lines
863 B
Python
def merge(a,b,m,e):
|
|
l=a[b:m+1]
|
|
r=a[m+1:e+1]
|
|
k=b
|
|
i=0
|
|
j=0
|
|
while i<len(l) and j<len(r):
|
|
#change sign for Descending order
|
|
if l[i]<r[j]:
|
|
a[k]=l[i]
|
|
i+=1
|
|
else:
|
|
a[k]=r[j]
|
|
j+=1
|
|
k+=1
|
|
while i<len(l):
|
|
a[k]=l[i]
|
|
i+=1
|
|
k+=1
|
|
while j<len(r):
|
|
a[k]=r[j]
|
|
j+=1
|
|
k+=1
|
|
return a
|
|
|
|
def mergesort(a,b,e):
|
|
"""
|
|
>>> mergesort([3,2,1],0,2)
|
|
[1, 2, 3]
|
|
>>> mergesort([3,2,1,0,1,2,3,5,4],0,8)
|
|
[0, 1, 1, 2, 2, 3, 3, 4, 5]
|
|
"""
|
|
if b<e:
|
|
m = (b+e)//2
|
|
#print("ms1",a,b,m)
|
|
mergesort(a,b,m)
|
|
#print("ms2",a,m+1,e)
|
|
mergesort(a,m+1,e)
|
|
#print("m",a,b,m,e)
|
|
merge(a,b,m,e)
|
|
return a
|
|
|
|
if __name__ == "__main__":
|
|
import doctest
|
|
doctest.testmod()
|