mirror of
https://github.com/TheAlgorithms/Python.git
synced 2025-04-20 12:47:35 +00:00
Update merge_sort.py (#2356)
* Update merge_sort.py * Update merge_sort.py
This commit is contained in:
parent
61dde44434
commit
cf385ad7ef
@ -1,44 +1,40 @@
|
|||||||
"""
|
"""
|
||||||
This is a pure Python implementation of the merge sort algorithm
|
This is a pure Python implementation of the merge sort algorithm
|
||||||
|
|
||||||
For doctests run following command:
|
For doctests run following command:
|
||||||
python -m doctest -v merge_sort.py
|
python -m doctest -v merge_sort.py
|
||||||
or
|
or
|
||||||
python3 -m doctest -v merge_sort.py
|
python3 -m doctest -v merge_sort.py
|
||||||
|
|
||||||
For manual testing run:
|
For manual testing run:
|
||||||
python merge_sort.py
|
python merge_sort.py
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
|
||||||
def merge_sort(collection):
|
def merge_sort(collection: list) -> list:
|
||||||
"""Pure implementation of the merge sort algorithm in Python
|
"""Pure implementation of the merge sort algorithm in Python
|
||||||
|
|
||||||
:param collection: some mutable ordered collection with heterogeneous
|
:param collection: some mutable ordered collection with heterogeneous
|
||||||
comparable items inside
|
comparable items inside
|
||||||
:return: the same collection ordered by ascending
|
:return: the same collection ordered by ascending
|
||||||
|
|
||||||
Examples:
|
Examples:
|
||||||
>>> merge_sort([0, 5, 3, 2, 2])
|
>>> merge_sort([0, 5, 3, 2, 2])
|
||||||
[0, 2, 2, 3, 5]
|
[0, 2, 2, 3, 5]
|
||||||
|
|
||||||
>>> merge_sort([])
|
>>> merge_sort([])
|
||||||
[]
|
[]
|
||||||
|
|
||||||
>>> merge_sort([-2, -5, -45])
|
>>> merge_sort([-2, -5, -45])
|
||||||
[-45, -5, -2]
|
[-45, -5, -2]
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def merge(left, right):
|
def merge(left: list, right: list) -> list:
|
||||||
"""merge left and right
|
"""merge left and right
|
||||||
:param left: left collection
|
:param left: left collection
|
||||||
:param right: right collection
|
:param right: right collection
|
||||||
:return: merge result
|
:return: merge result
|
||||||
"""
|
"""
|
||||||
result = []
|
def _merge():
|
||||||
while left and right:
|
while left and right:
|
||||||
result.append((left if left[0] <= right[0] else right).pop(0))
|
yield (left if left[0] <= right[0] else right).pop(0)
|
||||||
return result + left + right
|
yield from left
|
||||||
|
yield from right
|
||||||
|
return list(_merge())
|
||||||
|
|
||||||
if len(collection) <= 1:
|
if len(collection) <= 1:
|
||||||
return collection
|
return collection
|
||||||
@ -47,6 +43,8 @@ def merge_sort(collection):
|
|||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
|
import doctest
|
||||||
|
doctest.testmod()
|
||||||
user_input = input("Enter numbers separated by a comma:\n").strip()
|
user_input = input("Enter numbers separated by a comma:\n").strip()
|
||||||
unsorted = [int(item) for item in user_input.split(",")]
|
unsorted = [int(item) for item in user_input.split(",")]
|
||||||
print(*merge_sort(unsorted), sep=",")
|
print(*merge_sort(unsorted), sep=",")
|
||||||
|
Loading…
x
Reference in New Issue
Block a user