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++快速排序算法的主要内容,如果未能解决你的问题,请参考以下文章
500,000 个已排序整数数组上的 C++ 快速排序算法中的 Seg 错误