考虑以下C++代码实现的快速排序算法,将数据从 到 排序,则横线上应填的最佳代码是( )。 小 大
int partition(vector<int>& arr, int low, int high) {
int pivot = arr[high]; // 基准值
int i = low - 1;
for (int j = low; j < high; j++) {
________________________________ // 在此处填入代码
}
swap(arr[i + 1], arr[high]);
return i + 1;
}
// 快速排序
void quickSort(vector<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);
}
}
- A. 1 if (arr[j] > pivot) { 2 i++; 3 swap(arr[i], arr[j]); 4 }
- B. 1 if (arr[j] < pivot) { 2 i++; 3 swap(arr[i], arr[j]); 4 }
- C. 1 if (arr[j] < pivot) { 2 swap(arr[i], arr[j]); 3 i++; 4 }
- D. 1 if (arr[j] == pivot) { 2 i++; 3 swap(arr[i], arr[j]); 4 }
正确答案:B