第23601题 单选
结合给出的C++快速排序实现,判断下列关于快速排序的说法正确的是?
int partition(vector<int>& arr, int left, int right) {
    int pivot = arr[right]; // 基准值
    int i = left - 1;

    for (int j = left; j < right; j++) {
        if (arr[j] < pivot) {
            i++;
            swap(arr[i], arr[j]);
        }
    }
    swap(arr[i + 1], arr[right]);
    return i + 1;
}

// 快速排序
void quickSort(vector<int>& arr, int left, int right) {
    if (left < right) {
        int pi = partition(arr, left, right);
        quickSort(arr, left, pi - 1);
        quickSort(arr, pi + 1, right);
    }
}
A

快速排序通过递归对子问题进行求解。

B

快速排序的最坏时间复杂度是O(n)。

C

快速排序是一个稳定的排序算法。

D

在最优情况下,快速排序的时间复杂度是O(nlogn)。