首页 > 学院 > 开发设计 > 正文

数据结构实验之排序八:快速排序

2019-11-08 01:52:28
字体:
来源:转载
供稿:网友

数据结构实验之排序八:快速排序 Time Limit: 1000MS Memory Limit: 65536KB Submit Statistic PRoblem Description

给定N(N≤10^5)个整数,要求用快速排序对数据进行升序排列,注意不得使用STL。

Input

连续输入多组数据,每组输入数据第一行给出正整数N(≤10^5),随后给出N个整数,数字间以空格分隔。 Output

输出排序后的结果,数字间以一个空格间隔,行末不得有多余空格。 Example Input

8 49 38 65 97 76 13 27 49 Example Output

13 27 38 49 49 65 76 97 Hint

Author

接下来是快排的代码,说实在的,对这个代码一直不熟练,需要强加联系

#include <stdio.h>void qsort(int a[], int left, int right){ int x = a[left], i = left, j = right; if (left >= right) { return ; } 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; qsort(a, left, i - 1); qsort(a, i + 1, right);}int main(){ int n, a[100010], i; while (~scanf ("%d", &n)) { for (i = 0; i < n; i++) { scanf ("%d", &a[i]); } qsort(a, 0, n - 1); for (i = 0; i < n; i++) { printf ("%d%c", a[i], i < n - 1 ? ' ' : '/n'); } } return 0;}
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表