数据结构实验之排序一:一趟快排
Time Limit: 1000MS
Memory Limit: 65536KB
Problem Description
给定N个长整型范围内的整数,要求输出以给定数据中第一个数为枢轴进行一趟快速排序之后的结果。
Input
连续输入多组数据,每组输入数据第一行给出正整数N(N < = 10^5),随后给出N个长整型范围内的整数,数字间以空格分隔。
Output
输出一趟快速排序后的结果,数字间以一个空格间隔,行末不得有多余空格。
Example Input
8 49 38 65 97 76 13 27 49
Example Output
27 38 13 49 76 97 65 49
#include <bits/stdc++.h> using namespace std; void kuaipai(int a[], int l, int r) { int i, j, x; i = l, j = r, x = a[l]; if(l < r)//需要满足左边坐标小于右边 { while(i < j) { while(i < j && a[j] >= x)//右边的大于关键字 { j--; } a[i] = a[j];//右边小于关键字的与关键字交换 while(i < j && a[i] <= x)//左边的小于关键字 { i++; } a[j] = a[i];//左边大于关键字的与关键字交换 }
a[i] = x; } } int main() { int n, i; int a[100005]; while(cin >> n) { for(i = 0; i < n; i++) { cin >> a[i]; } kuaipai(a, 0, n-1); for(i = 0; i < n-1; i++) { cout << a[i] << " "; } cout << a[n-1] << endl; } return 0; }