Курс 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"

  1. Настройка вывода NumPy
  2. Логические операторы в Python
  3. Поиск с библиотекой Google
  4. Оптимизация гиперпараметров с Scikit Optimize
  5. Нахождение самого длинного слова в списке с помощью max
  6. Генерация фальшивых данных с Faker
  7. Замена символов в строке
  8. Модуль pprint: улучшение вывода данных
  9. Создание и использование модулей в Python
  10. Метод repr() в Python
  11. Модуль Operator в Python
  12. Эффективная конкатенация строк в Python
  13. Работа с контекстным менеджером Pool
  14. Генераторы в Python
  15. Метод ifloordiv для пользовательских классов
  16. Библиотека itertools: объединение списков
  17. Defaultdict в Python
  18. Профилирование кода на Python
  19. Кортеж в Python: создание и использование
  20. Работа с базами данных SQLite
  21. Работа с файлами в Python
  22. Создание итератора
  23. Работа с YAML в Python
  24. Создание словарей с defaultdict
  25. Генераторы в Python
  26. Метод setdefault() в Python
  27. Создание директории в Python
  28. Поиск кода
  29. Настройка логгера Logzero
  30. Сложные типы данных в Python
  31. Создание списка через цикл
  32. Работа с очередями в Python
  33. Переопределение метода __lshift__
  34. Распаковка с оператором *
  35. PrettyTable: создание таблицы
  36. Работа с дробями в Python
  37. Python и Юникод: работа с цифрами
  38. Работа с IP-адресами в Python
  39. Основные операции с библиотекой Numpy
  40. Основы работы с базами данных в Python
  41. Работа с асинхронными задачами в Python
  42. Вывод сложных структур данных с помощью pprint
  43. Запуск внешнего кода в Jupyter
  44. Группировка элементов в словарь
  45. Создание и удаление объектов
  46. Проверка типов с помощью isinstance

Marketello читают маркетологи из крутых компаний