快速排序实现的C++函数模板

快速排序(Quicksort)算法是一种常用的基于比较的排序算法,其时间复杂度为O(nlogn)。在该算法中,通过选择枢纽元素将待排序数组分割成两个子序列,其中一个子序列的所有元素都小于枢纽元素,另外一个子序列的所有元素都大于等于枢纽元素。然后递归的排序这两个子序列。

下面是快速排序实现的C++函数模板:

template <typename T>
void quick_sort(vector<T>& arr, int left, int right) {
    if (left >= right) {
        return;
    }
    int i = left;
    int j = right;
    T 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--;
        }
    }
    quick_sort(arr, left, j);
    quick_sort(arr, i, right);
}

一、快速排序的原理和算法流程

在快速排序算法中,通过选择一个枢纽元素,将待排序的数组分割成两个子序列。枢纽元素选取的方式有多种,例如可以选择第一个元素、最后一个元素或者中间的元素。通常情况下,我们选择中间的元素作为枢纽元素,因为这样可以避免最坏时间复杂度的出现。

算法流程如下:

  • 1. 选择一个枢纽元素pivot,一般取数组中间的元素
  • 2. 将待排序数组分成两个子序列,一个序列中所有元素都小于pivot,另一个序列中所有元素都大于等于pivot
  • 3. 对这两个子序列递归执行第1步和第2步操作

二、实现细节和优化

快速排序是一种高效的排序算法,但是在实际使用中,存在一些需要注意的实现细节和优化点,下面列举一些:

  • 1. 在枢纽元素的选择上,可以采用三数取中的方式,即选择左、中、右三个元素的中位数作为枢纽元素。这种方式可以避免在排序的过程中出现最坏情况。
  • 2. 在排序前,可以对待排序数组进行一次随机打乱,这样可以避免在数组已经有序或者近乎有序的情况下出现最坏情况。
  • 3. 迭代实现快速排序比递归实现快速排序更高效,因为在递归实现中需要调用函数和压栈,需要耗费额外的时间和空间。
  • 4. 对于小规模的数组,使用插入排序或者选择排序可以提高快速排序的效率。
  • 5. 在实际使用中,可以使用STL中的sort函数替代手写的快速排序,这样可以避免一些实现细节和错误。

三、快速排序的应用场景

快速排序是一种常见的排序算法,广泛应用于各种软件系统中,例如:

  • 1. 数据库系统中对数据进行排序
  • 2. 操作系统中进行进程/线程调度
  • 3. 计算机网络中对数据进行排序
  • 4. 一些组合优化问题中的求解方法

四、代码示例

下面是使用上述快速排序函数模板的示例,对一个整数数组进行排序:

#include <iostream>
#include <vector>
using namespace std;

template <typename T>
void quick_sort(vector<T>& arr, int left, int right) {
    if (left >= right) {
        return;
    }
    int i = left;
    int j = right;
    T 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--;
        }
    }
    quick_sort(arr, left, j);
    quick_sort(arr, i, right);
}

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

原创文章,作者:RGAV,如若转载,请注明出处:https://www.506064.com/n/142751.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
RGAVRGAV
上一篇 2024-10-12 09:45
下一篇 2024-10-12 09:45

相关推荐

  • Python中引入上一级目录中函数

    Python中经常需要调用其他文件夹中的模块或函数,其中一个常见的操作是引入上一级目录中的函数。在此,我们将从多个角度详细解释如何在Python中引入上一级目录的函数。 一、加入环…

    编程 2025-04-29
  • Python中capitalize函数的使用

    在Python的字符串操作中,capitalize函数常常被用到,这个函数可以使字符串中的第一个单词首字母大写,其余字母小写。在本文中,我们将从以下几个方面对capitalize函…

    编程 2025-04-29
  • Ojlat:一款快速开发Web应用程序的框架

    Ojlat是一款用于快速开发Web应用程序的框架。它的主要特点是高效、易用、可扩展且功能齐全。通过Ojlat,开发人员可以轻松地构建出高质量的Web应用程序。本文将从多个方面对Oj…

    编程 2025-04-29
  • Python中set函数的作用

    Python中set函数是一个有用的数据类型,可以被用于许多编程场景中。在这篇文章中,我们将学习Python中set函数的多个方面,从而深入了解这个函数在Python中的用途。 一…

    编程 2025-04-29
  • 三角函数用英语怎么说

    三角函数,即三角比函数,是指在一个锐角三角形中某一角的对边、邻边之比。在数学中,三角函数包括正弦、余弦、正切等,它们在数学、物理、工程和计算机等领域都得到了广泛的应用。 一、正弦函…

    编程 2025-04-29
  • 单片机打印函数

    单片机打印是指通过串口或并口将一些数据打印到终端设备上。在单片机应用中,打印非常重要。正确的打印数据可以让我们知道单片机运行的状态,方便我们进行调试;错误的打印数据可以帮助我们快速…

    编程 2025-04-29
  • Python3定义函数参数类型

    Python是一门动态类型语言,不需要在定义变量时显示的指定变量类型,但是Python3中提供了函数参数类型的声明功能,在函数定义时明确定义参数类型。在函数的形参后面加上冒号(:)…

    编程 2025-04-29
  • 心形照片拼图模板

    如何使用心形照片拼图模板 一、模板介绍 心形照片拼图模板是一种让用户可以将自己的照片拼接成一个心形的巧妙设计,每个照片都是一个拼图块,当所有的照片配合完成时,呈现出一个完整的心形。…

    编程 2025-04-29
  • Python定义函数判断奇偶数

    本文将从多个方面详细阐述Python定义函数判断奇偶数的方法,并提供完整的代码示例。 一、初步了解Python函数 在介绍Python如何定义函数判断奇偶数之前,我们先来了解一下P…

    编程 2025-04-29
  • Python实现计算阶乘的函数

    本文将介绍如何使用Python定义函数fact(n),计算n的阶乘。 一、什么是阶乘 阶乘指从1乘到指定数之间所有整数的乘积。如:5! = 5 * 4 * 3 * 2 * 1 = …

    编程 2025-04-29

发表回复

登录后才能评论