✏️ 纠错
第 190 题 / 共 251 题
第14题 关于下述C++代码的快速排序算法,说法错误的是( )。
int randomPartition(std::vector<int>& arr, int low, int high) {
    int random = low + rand() % (high - low + 1);
    std::swap(arr[random], arr[high]);

    int pivot = arr[high];
    int i = low - 1;

    for (int j = low; j < high; j++) {
        if (arr[j] <= pivot) {
            i++;
            std::swap(arr[i], arr[j]);
        }
    }
    std::swap(arr[i + 1], arr[high]);
    return i + 1;
}

void quickSort(std::vector<int>& arr, int low, int high) {
    if (low < high) {
        int pi = randomPartition(arr, low, high);

        quickSort(arr, low, pi - 1);
        quickSort(arr, pi + 1, high);
    }
}
📝 题目解析

答案:D

知识点:快速排序算法的原理,包括随机选择基准值、划分函数的作用、时间复杂度和稳定性

解析:A正确,i始终指向小于等于基准值的最后一个元素,其右侧为大于基准值的元素;B正确,随机选择基准值可避免有序数组等极端情况的O(n2)复杂度;C正确,快排平均复杂度为O(nlogn);D错误,快排中相同元素的相对位置可能因交换改变,因此是不稳定排序。