c++快速排序算法

Posted lja001162

tags:

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

c++快速排序算法

题目描述

利用快速排序算法将读入的NN个数从小到大排序后输出。

快速排序是信息学竞赛的必备算法之一。对于快速排序不是很了解的同学可以自行上网查询相关资料,掌握后独立完成。(C++选手请不要试图使用STL,虽然你可以使用sort一遍过,但是你并没有掌握快速排序算法的精髓。)

输入输出格式

输入格式:

第11行为一个正整数NN,第22行包含NN个空格隔开的正整数a_iai,为你需要进行排序的数,数据保证了A_iAi不超过10000000001000000000。

输出格式:

将给定的NN个数从小到大输出,数之间空格隔开,行末换行且无空格。

输入输出样例

输入样例#1:

5
4 2 4 5 1

输出样例#1:

1 2 4 4 5

代码及注释

#include <iostream>
using namespace std;
void qsort(int, int);
int a[101];
int change(int,int);
int main()

    int n;
    cin >> n;
    for (int i = 1; i <= n;i ++)//输入  
    
        cin >> a[i];
    
    qsort(1, n);
    for (int i = 1; i <= n;i ++)//输出 
    
        cout << a[i] << " ";
    
//    cout << endl;
//    return 0;

void qsort(int l,int r)

    int mid, p;// mid是中间值  
    int j, i;//i是左边 j是右边  
    i = l;
    j = r;
    mid = a[(l + r) / 2];//取中间的一个数  
    do
    
        while (a[i] < mid)//如果指的数大于中间就停 
        
            i++;
        
        while (a[j] > mid)//如果指的数小于中间就停 
        
            j--;
        
        if (i <= j)//如果i在左边; j在右边 
        
            if (a[i] != a[j])//交换 
            
                p = a[i];
                a[i] = a[j];
                a[j] = p;
            
            i++;//各自移动 
            j--;
        
     while (i <= j);
    if (l < j)//排中间值左边的 
        qsort(l, j);
    if (i < r)//排中间值右边的 
        qsort(i, r);

/* 
9
3 5 8 1 2 9 4 7 6
*/ 

算法视频

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

排序算法的c++实现——快速排序

500,000 个已排序整数数组上的 C++ 快速排序算法中的 Seg 错误

C ++快速排序算法崩溃[关闭]

在最佳情况下,由于堆栈溢出错误,快速排序算法失败 - C++

C++入门:排序之快速排序

快速排序算法的C++实现