经典排序算法——快速排序

Posted zhihua_bupt

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了经典排序算法——快速排序相关的知识,希望对你有一定的参考价值。

对于一个int数组,请编写一个快速排序算法,对数组元素排序。

给定一个int数组A及数组的大小n,请返回排序后的数组。

测试样例:
[1,2,3,5,2,3],6

[1,2,2,3,3,5]

class QuickSort {
public:
    int* quickSort(int* A, int n) {
        // write code here
        if(A==NULL || n<2)
            return A;
        process(A,0,n-1);
        return A;
    }
    
    int* process(int* A, int low,int high) {
        if (low < high) {
            int mid = partition(A, low, high);
            process(A, low, mid-1);//对A[low...mid-1]进行递归操作排序
            process(A, mid + 1, high);//对A[mid+1...high]进行递归操作排序
        }
        return A;
    }
    
    int partition(int* A,int low,int high){ //快排算法的划分过程,将数组划分为左右两个子数组
        int pivot = A[low];
        int i = low;
        int j = high;
        if (low < high) 
        {
            while (i < j) 
            {
                while (i < j && pivot <= A[j])  j--;//找到比基准数小的元素
                if (i < j)  A[i] = A[j];
                while (i < j && pivot >= A[i])  i++;//找到比基准数大的元素
                if (i < j)  A[j] = A[i];
            }
            A[i] = pivot;
        }
        return i;
    }
};

技术分享



以上是关于经典排序算法——快速排序的主要内容,如果未能解决你的问题,请参考以下文章

[新星计划] Python手撕代码 | 十大经典排序算法

[新星计划] Python手撕代码 | 十大经典排序算法

九种经典排序算法详解(冒泡排序,插入排序,选择排序,快速排序,归并排序,堆排序,计数排序,桶排序,基数排序)

十大经典排序算法总结(基数排序)

十大经典排序算法总结(归并排序)

十大经典排序算法总结(桶排序)