GESP C++ 真题 · 逐题精解
首页C++五级真题 › 2024年6月 › 第9题

GESP 2024年6月 C++五级 单选题 第9题

C++五级单选题2024年6月第9题

所属知识点:分治与递归 难度要求:掌握 考频:—

为了正确实现快速排序,下面横线上的代码应为( )。
void qsort(vector<int>& arr, int left, int right) {
int i, j, mid;
int pivot;
i = left;
j = right;
mid = (left + right) / 2; // 计算中间元素的索引
pivot = arr[mid]; // 选择中间元素作为基准值
do {
while (arr[i] < pivot) i++;
while (arr[j] > pivot) j--;
if (i <= j) {
swap(arr[i], arr[j]); // 交换两个元素
i++; j--;
}
} ________________________________; // 在此处填入代码
if (left < j) qsort(arr, left, j);   // 对左子数组进行快速排序
if (i < right) qsort(arr, i, right); // 对右子数组进行快速排序
}

正确答案:D

题目解析

快排一次划分的循环条件是 while(i<=j),选 D。……

完整解析为会员内容二级及以上的逐题精讲需开通 VIP。一级解析全部免费。前往 GESPPASS 解锁

想系统刷完 GESP C++ 1~8 级真题,并查看每道题的逐题精讲?

进入 GESPPASS 开始练习