用C++写一段快排算法
以下是C++实现的快速排序算法:
#include <iostream>
using namespace std;
void quickSort(int arr[], int left, int right) {
int i = left, j = right;
int pivot = arr[(left + right) / 2];
while (i <= j) {
while (arr[i] < pivot) {
i++;
}
while (arr[j] > pivot) {
j--;
}
if (i <= j) {
swap(arr[i], arr[j]);
i++;
j--;
}
}
if (left < j) {
quickSort(arr, left, j);
}
if (i < right) {
quickSort(arr, i, right);
}
}
int main() {
int arr[] = { 5, 3, 8, 4, 2, 7, 1, 6 };
int n = sizeof(arr) / sizeof(arr[0]);
quickSort(arr, 0, n - 1);
for (int i = 0; i < n; i++) {
cout << arr[i] << " ";
}
cout << endl;
return 0;
}
在快速排序函数中,我们定义了左边界i和右边界j,并选择以数组中间的元素pivot为基准进行分区。在分区过程中,我们将左边小于基准的元素和右边大于基准的元素进行交换,直到i和j相遇。然后,我们递归地对基准左边和右边的子数组进行排序。最终,我们可以得到一个按升序排列的数组。
原文地址: https://www.cveoy.top/t/topic/bDnA 著作权归作者所有。请勿转载和采集!