• c++快速排序算法


    c++快速排序算法

    题目描述

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

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

    输入输出格式

    输入格式:

    第11行为一个正整数NN,第22行包含NN个空格隔开的正整数a_ia**i,为你需要进行排序的数,数据保证了A_iA**i不超过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
    */ 
    

    STL代码

    虽然题目上不允许用STL
    但是
    我还是用了
    上代码

    #include <iostream>
    #include <algorithm>//STL库函数
    using namespace std;
    int main()
    {
        int arrays[100];
        int n;
        cin >> n;
        for (int i = 1;i <= n;i ++)
        {
            cin >> arrays[i];
        }
        sort(arrays,arrays + n + 1);//STL排序函数
        for (int i = 1;i <= n;i ++)
        {
            cout << arrays[i] << " ";
        }
        cout << endl;
        return 0;
    }
    
    

    算法视频

  • 相关阅读:
    解决Chrome关联HTML文件,图标不显示的问题。
    Tomcat启动超时问题Server Tomcat v7.0 Server at localhost was unable to start within 45 seconds
    matlalb 的后台运行方式
    新转移注意(caffe):ImportError: libcudart.so.7.0: cannot open shared object file: No such file or directory
    查看nvidia显卡命令
    train validation test
    lmdb数据格式
    github
    2016 hosts
    opencv3.0 imread问题
  • 原文地址:https://www.cnblogs.com/LJA001162/p/11072454.html
Copyright © 2020-2023  润新知