单选题

考虑以下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 log n)。

C

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

D

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

赣ICP备20007335号-2