-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathselection_sort.py
More file actions
56 lines (45 loc) · 2.18 KB
/
selection_sort.py
File metadata and controls
56 lines (45 loc) · 2.18 KB
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
51
52
53
54
55
56
import random
def selection_sort(array, type_sort='asc'):
"""
Метод реализует сортировку выборкой.
:param array: должен быть списком для сортировки.
:param type_sort: аргумент что принимает параметры "asc" или "desc"
и в зависимости от этого сортирует по возрастанию или убыванию.
:return: None
"""
print('Array for sorting : ', array)
counter = 0
result_aray = []
# Цикл для определения
while True:
# Каждый раз устанавливаем длину списка заново, что бы
# не выйти за границу списка
array_len = len(array)
current, number = array[0], 0
# Если в начальном списке остался 1 элемент то он автоматически
# является минимальным, добавляем его и выходим из цикла
if array_len == 1:
result_aray.append(array[0])
break
# Проходимся по списку и сравниваем наше значение с
# каждым знач в списке, и определяем большее
for j in range(array_len):
counter += 1
if type_sort == 'asc':
if current < array[j]:
number = j
current = array[j]
elif type_sort == 'desc':
if current > array[j]:
number = j
current = array[j]
# Добавляем элемента в финальный список и
# удаляем из изначального массива
result_aray.append(current)
del array[number]
print('Результат :')
print('Количество шагов = ', counter)
print('Финальный массив = ', result_aray)
random_array = [random.randint(0, 10) for i in range(1, 11)]
selection_sort(random_array, 'asc')
# selection_sort(random_array, 'desc')