递归方法实现快速排序使用c++
时间: 2024-05-09 08:12:47 浏览: 231
递归方法实现快速排序的基本思路如下:
1. 选取一个基准值(pivot),将待排序数组分为两部分,一部分小于等于基准值,一部分大于基准值;
2. 对左右两部分递归执行上述步骤,直到每部分只剩一个元素或为空。
以下是使用 C++ 实现递归方法的快速排序示例代码:
```c++
#include <iostream>
#include <vector>
using namespace std;
void quickSort(vector<int>& arr, int left, int right) {
if (left >= right) {
return;
}
int i = left, j = right, pivot = arr[left];
while (i < j) {
while (i < j && arr[j] >= pivot) {
j--;
}
arr[i] = arr[j];
while (i < j && arr[i] <= pivot) {
i++;
}
arr[j] = arr[i];
}
arr[i] = pivot;
quickSort(arr, left, i - 1);
quickSort(arr, i + 1, right);
}
int main() {
vector<int> arr = {5, 1, 9, 3, 7};
quickSort(arr, 0, arr.size() - 1);
for (int i = 0; i < arr.size(); i++) {
cout << arr[i] << " ";
}
cout << endl;
return 0;
}
```
阅读全文