Программа будет сортировать список методом подсчета (Counting sort).

Алгоритм
Подсчитываем, сколько раз в массиве встречается каждое значение, и заполняем массив подсчитанными элементами в соответствующих количествах. Счётчики для всего диапазона чисел создаются заранее (изначально равны нулю).
Сложность сортировки по времени
- Худшая O(n + k)
- Средняя O(n + k)
- Лучшая O(n)
Шаги к правильному решению
- Создадим функцию
counting_sort, которая принимает на вход список и переменнуюlargest. - Внутри функции создадим список c нулями и длиной
largest+1. - Для каждого элемента входного списка увеличиваем значение элемента таким образом
c[alist[i]] = c[alist[i]] + 1. - Теперь список с содержит частоту каждого элемента входного списка.
- Каждому элементу от 1 до
length(c) -1добавляем к значению текущего элемента значение предыдущегоc[i] = c[i] + c[i - 1]. - Создадим
resultсписок с таким же размером, как и входной список. - Создадим цикл, который итерируется по списку в обратном порядке.
- В каждой итерации цикла установим
result[c[x]] = x, а затем уменьшимc[x]на 1.
def counting_sort(alist, largest):
c = [0]*(largest + 1)
for i in range(len(alist)):
c[alist[i]] = c[alist[i]] + 1
# Find the last index for each element
c[0] = c[0] - 1 # to decrement each element for zero-based indexing
for i in range(1, largest + 1):
c[i] = c[i] + c[i - 1]
result = [None]*len(alist)
# Though it is not required here,
# it becomes necessary to reverse the list
# when this function needs to be a stable sort
for x in reversed(alist):
result[c[x]] = x
c[x] = c[x] - 1
return result
alist = input('Enter the list of (nonnegative) numbers: ').split()
alist = [int(x) for x in alist]
k = max(alist)
sorted_list = counting_sort(alist, k)
print('Sorted list: ', end='')
print(sorted_list)
