-
-
Notifications
You must be signed in to change notification settings - Fork 46.6k
/
Copy pathstalin_sort.py
50 lines (35 loc) · 1.1 KB
/
stalin_sort.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
"""
Stalin Sort algorithm: Removes elements that are out of order.
Elements that are not greater than or equal to the previous element are discarded.
Reference: https://medium.com/@kaweendra/the-ultimate-sorting-algorithm-6513d6968420
"""
def stalin_sort(sequence: list[int]) -> list[int]:
"""
Sorts a list using the Stalin sort algorithm.
>>> stalin_sort([4, 3, 5, 2, 1, 7])
[4, 5, 7]
>>> stalin_sort([1, 2, 3, 4])
[1, 2, 3, 4]
>>> stalin_sort([4, 5, 5, 2, 3])
[4, 5, 5]
>>> stalin_sort([6, 11, 12, 4, 1, 5])
[6, 11, 12]
>>> stalin_sort([5, 0, 4, 3])
[5]
>>> stalin_sort([5, 4, 3, 2, 1])
[5]
>>> stalin_sort([1, 2, 3, 4, 5])
[1, 2, 3, 4, 5]
>>> stalin_sort([1, 2, 8, 7, 6])
[1, 2, 8]
"""
if any(x < 0 for x in sequence):
raise ValueError("Sequence must only contain non-negative integers")
result = [sequence[0]]
for i in range(1, len(sequence)):
if sequence[i] >= result[-1]:
result.append(sequence[i])
return result
if __name__ == "__main__":
import doctest
doctest.testmod()