Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Задачи

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про JavaScript: merge sort, divide and conquer, time complexity, sorting algorithm

Как работает сортировка слиянием и какова её сложность?

Вопрос проверяет понимание алгоритма сортировки слиянием, его принципа работы и временной сложности, что важно для оценки навыков алгоритмического мышления.

Короткий ответ

Сортировка слиянием — это алгоритм типа «разделяй и властвуй». Он рекурсивно делит массив на две половины, сортирует каждую, а затем сливает их в упорядоченный результат. Временная сложность всегда O(n log n), а дополнительная память O(n).

Длинный ответ

Как работает сортировка слиянием

Сортировка слиянием (Merge Sort) — это эффективный алгоритм сортировки, основанный на принципе «разделяй и властвуй». Он рекурсивно разбивает исходный массив на две равные части до тех пор, пока каждая часть не будет состоять из одного элемента (такой массив считается отсортированным). Затем происходит слияние этих частей в правильном порядке.

Пример реализации на JavaScript

function mergeSort(arr) {
  if (arr.length <= 1) return arr;
  const mid = Math.floor(arr.length / 2);
  const left = mergeSort(arr.slice(0, mid));
  const right = mergeSort(arr.slice(mid));
  return merge(left, right);
}

function merge(left, right) {
  let result = [];
  let i = 0, j = 0;
  while (i < left.length && j < right.length) {
    if (left[i] < right[j]) result.push(left[i++]);
    else result.push(right[j++]);
  }
  return result.concat(left.slice(i)).concat(right.slice(j));
}

Сложность алгоритма

  • Временная сложность: O(n log n) в лучшем, среднем и худшем случаях, так как массив всегда делится пополам, а слияние требует O(n).
  • Пространственная сложность: O(n) из-за необходимости дополнительного массива для слияния.

Применение

Сортировка слиянием часто используется для сортировки больших объёмов данных, особенно когда важна стабильность (сохранение порядка равных элементов) и предсказуемая производительность. Она также применяется во внешних сортировках, когда данные не помещаются в оперативную память.

Вывод: Сортировка слиянием — надёжный выбор для задач, где требуется гарантированная производительность O(n log n) и стабильность, но стоит учитывать её потребление дополнительной памяти.

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.

Уровень

  • Рейтинг:

    4

  • Сложность:

    5

Навыки

  • JavaScript

    JavaScript

Ключевые слова

#merge sort

#divide and conquer

#time complexity

#sorting algorithm

Подпишись на Golang Developer в телеграм

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.