✏️ 纠错
第 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错误,快排中相同元素的相对位置可能因交换改变,因此是不稳定排序。