排序-快速排序

#include<iostream>
#include<math.h>
using namespace std;

void quick_sort(int s[], int l, int r)
{
    if (l > r)
        return;
    int i = l, j = r, x = s[l];
    while (i < j)
    {
        while (i < j&&s[j] >= x)
            j--;
        if (i < j)
            s[i++] = s[j];
        while (i < j&&s[i] < x)
            i++;
        if (i < j)
            s[j--] = s[i];
    }
    s[i] = x;
    quick_sort(s, l, i - 1);
    quick_sort(s, i + 1, r);
}

int main()
{
    int a[] = { 4,3,54,2,554,6 };
    quick_sort(a, 0, 5);
    for (int i=0;i<6;i++)
    {
        cout << a[i]<<" ";
    }
    system("pause");
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容