快速排序标准C++代码
时间: 2024-06-11 20:02:37 浏览: 14
快速排序是一种常见的排序算法,它的时间复杂度为O(nlogn)。下面是快速排序的标准C++代码:
```
void quickSort(int arr[], int left, int right) {
int i = left, j = right;
int tmp;
int pivot = arr[(left + right) / 2];
/* partition */
while (i <= j) {
while (arr[i] < pivot)
i++;
while (arr[j] > pivot)
j--;
if (i <= j) {
tmp = arr[i];
arr[i] = arr[j];
arr[j] = tmp;
i++;
j--;
}
};
/* recursion */
if (left < j)
quickSort(arr, left, j);
if (i < right)
quickSort(arr, i, right);
}
```
其中,left和right是数组的左右下标,pivot是选定的基准数。该算法会先选定一个基准数,然后将数组分为两个部分,一部分是小于基准数的数,一部分是大于基准数的数。接着,对这两部分递归进行快速排序。