Sobes.tech
Back to questions
Junior — Middle
66

Как определить временную сложность алгоритма быстрой сортировки?

Companies where asked
Передовые Платежные Решения

Answer from AI

sobes.tech AI

Временная сложность алгоритма быстрой сортировки (QuickSort) зависит от выбора опорного элемента (pivot) и распределения данных.

  • В среднем и лучшем случае сложность — O(n log n), где n — количество элементов. Это происходит, когда массив делится примерно пополам на каждом шаге.
  • В худшем случае (например, когда массив уже отсортирован и выбирается крайний элемент как pivot) сложность становится O(n²).

Для оценки временной сложности анализируют количество сравнений и перестановок на каждом уровне рекурсии и суммируют по всем уровням.

Пример вызова быстрой сортировки на Java:

public void quickSort(int[] arr, int low, int high) {
    if (low < high) {
        int pi = partition(arr, low, high);
        quickSort(arr, low, pi - 1);
        quickSort(arr, pi + 1, high);
    }
}

Здесь partition — функция, которая выбирает pivot и разделяет массив.