码迷,mamicode.com
首页 > 编程语言 > 详细

c++快速排序算法

时间:2019-06-23 13:58:06      阅读:128      评论:0      收藏:0      [点我收藏+]

标签:stream   main   https   换行   数据   快速排序算法   大于   end   http   

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++快速排序算法

标签:stream   main   https   换行   数据   快速排序算法   大于   end   http   

原文地址:https://www.cnblogs.com/LJA001162/p/11072454.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!