117.info
人生若只如初见

c++快排函数如何实现高效排序

C++中的快速排序(Quick Sort)是一种高效的排序算法,其基本思想是通过选取一个基准元素,将数组分为两部分,使得一部分的元素都小于基准元素,另一部分的元素都大于基准元素,然后对这两部分递归地进行快速排序。

以下是一个简单的C++快速排序实现:

#include
#include
using namespace std;

// 快速排序的分区函数
int partition(vector<int>& arr, int low, int high) {
    int pivot = arr[low]; // 选取第一个元素作为基准
    while (low< high) {
        while (low< high && arr[high] >= pivot) {
            high--;
        }
        arr[low] = arr[high]; // 将比基准小的元素移到左边
        while (low< high && arr[low] <= pivot) {
            low++;
        }
        arr[high] = arr[low]; // 将比基准大的元素移到右边
    }
    arr[low] = pivot; // 把基准元素放到正确的位置
    return low; // 返回基准元素的索引
}

// 快速排序的递归函数
void quickSort(vector<int>& arr, int low, int high) {
    if (low< high) {
        int pivotIndex = partition(arr, low, high); // 获取基准元素的索引
        quickSort(arr, low, pivotIndex - 1); // 对左侧子数组进行快速排序
        quickSort(arr, pivotIndex + 1, high); // 对右侧子数组进行快速排序
    }
}

int main() {
    vector arr = {3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5};
    quickSort(arr, 0, arr.size() - 1);
    for (int i = 0; i < arr.size(); i++) {
        cout<< arr[i] << " ";
    }
    cout<< endl;
    return 0;
}

这个实现中,partition函数用于将数组划分为两部分,quickSort函数则是递归地对这两部分进行排序。在main函数中,我们创建了一个包含一些整数的向量,并调用quickSort函数对其进行排序。最后,我们打印出排序后的结果。

未经允许不得转载 » 本文链接:https://www.117.info/ask/fef9eAzsBBQ5UDQ.html

推荐文章

  • c# value在循环中的应用

    在C#中,可以在循环中使用value来保存每次迭代的值。这可以用于记录循环中每个元素的值,或者在循环中进行一些计算或操作。
    例如,可以在for循环中使用valu...

  • c# value怎样提高性能

    提高C#程序性能的方法有很多,以下是一些建议: 使用合适的数据结构和算法:选择合适的数据结构和算法可以显著提高程序性能,避免不必要的循环和递归操作。 避免...

  • c# value数组操作指南

    在C#中,数组是一种用于存储固定大小的元素集合的数据结构。数组可以包含相同类型的元素,并且可以通过索引访问和操作这些元素。以下是一些常见的数组操作指南:...

  • c# value与const的区别

    Value是一个关键字,用于声明变量,表示该变量可以被更改。而const也是一个关键字,用于声明常量,表示该变量的值在程序运行过程中不能被改变。 Value声明的变量...

  • 如何优化c++中fopen函数的性能

    fopen 是 C++ 中用于打开文件的函数,它本身的性能优化空间有限 使用缓冲区:当你使用 fopen 读取或写入文件时,使用缓冲区可以显著提高性能。setvbuf 函数可以设...

  • c++中fopen函数的错误处理机制是什么

    在C++中,fopen函数用于打开一个文件以进行读取或写入 返回值检查:当fopen函数成功打开文件时,它会返回一个指向FILE对象的指针。如果打开文件失败,fopen将返回...

  • c++中如何避免coredump的发生

    在C++中,避免core dump(核心转储)的发生可以通过以下方法来实现: 使用智能指针:C++11引入了智能指针,如std::shared_ptr和std::unique_ptr,它们可以自动管...

  • 如何分析c++程序的coredump文件

    分析 C++ 程序的 coredump 文件通常需要以下几个步骤: 获取 coredump 文件:当程序崩溃时,操作系统会生成一个包含程序运行时内存信息的文件。这个文件就是 cor...