以下是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相遇。然后,我们递归地对基准左边和右边的子数组进行排序。最终,我们可以得到一个按升序排列的数组。

用C++写一段快排算法

原文地址: https://www.cveoy.top/t/topic/bDnA 著作权归作者所有。请勿转载和采集!

免费AI点我,无需注册和登录