Курс Python → Сортировка слиянием
Алгоритм сортировки слиянием является одним из наиболее эффективных методов сортировки массивов. Он основан на стратегии «разделяй и властвуй», которая заключается в разделении исходного массива на две равные части, сортировке каждой из них отдельно, а затем объединении отсортированных подмассивов в один отсортированный массив. Этот подход позволяет эффективно сортировать массивы любого размера.
Для реализации алгоритма сортировки слиянием на Python можно написать функцию, которая будет рекурсивно разделять и сортировать массив. Начнем с базового случая — когда массив содержит только один элемент, в этом случае он уже отсортирован. Затем рекурсивно делим массив пополам, пока не дойдем до базового случая, после чего начинаем объединять и сортировать подмассивы.
def merge_sort(arr):
if len(arr) <= 1:
return arr
mid = len(arr) // 2
left = merge_sort(arr[:mid])
right = merge_sort(arr[mid:])
return merge(left, right)
def merge(left, right):
result = []
i = j = 0
while i < len(left) and j < len(right):
if left[i] < right[j]:
result.append(left[i])
i += 1
else:
result.append(right[j])
j += 1
result.extend(left[i:])
result.extend(right[j:])
return result
arr = [3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5]
sorted_arr = merge_sort(arr)
print(sorted_arr)
В данном примере функция merge_sort рекурсивно разделяет и сортирует массив arr, а функция merge объединяет и сортирует два отсортированных подмассива. После вызова merge_sort для исходного массива, мы получаем отсортированный массив sorted_arr, который затем можно использовать в дальнейшем коде.
Алгоритм сортировки слиянием имеет сложность O(n log n), что делает его одним из наиболее эффективных методов сортировки. Он также устойчив, что означает, что порядок элементов с одинаковыми значениями не меняется после сортировки. Этот алгоритм широко используется в практике программирования и может быть полезен при работе с большими массивами данных.
Другие уроки курса "Python"
- Оператор объединения словарей
- Именованные кортежи в Python
- Сравнение строк в Python
- Работа с словарями в Python
- Замена текста с помощью sub
- Сокращение ссылок с pyshorteners
- Лямбда-функции в Python
- Метод rlshift для битового сдвига
- Названия переменных
- Карта бомбоубежищ в Москве и Питере
- Логирование с Logzero
- Подсчет элементов с помощью Counter из collections
- Методы и функции в Python
- Форматирование строк в Python
- Работа с YAML в Python
- Python Метод sleep() из time
- JSON в Python: модуль, dump, dumps, load
- Работа с NumPy.linalg
- F-строки в Python
- Оператор del в Python
- F-строки в Python 3.8
- Функция product() в Python
- Документация функции help() в Python
- Создание новых списков
- Создание списка через итерацию
- Копирование объектов в Python
- Проверка запуска скрипта или импорта модуля
- Подробная информация о %pinfo
- Создание и инициализация объектов
- Автоматизация скриптов на AWS Lightsail.
- Избегайте пустого списка
- Просмотр атрибутов и методов класса
- Работа с GitHub в Telegram
- Получение размера объекта с sys.getsizeof()
- Вставка переменных в шаблоны Flask
- Defaultdict в Python
- Анализ кода — Python
- Печать списка с помощью метода join
- Комментарии в Python
- Особенности запятых в Python
- Преобразование чисел в восьмеричную строку
- Оптимизация памяти в Python
- Метод __ilshift__ для битового сдвига влево
- Работа с collections в Python.
- Наиболее частотные элементы с помощью Counter
- Удаление ключа из словаря в Python
- Форматирование строк с помощью f-строк















