快速排序
#include <iostream>
using namespace std;
int a[50001];
int qs(int s, int e)
{
int x = a[s], l = s, r = e;
if(l >= r)
return 0;
while (l < r)
{
while(l<r && a[r]>=x) //從右向左掃描
r--;
a[l] = a[r];
while(l<r && a[l]<=x) //從左向右掃描
l++;
a[r] = a[l];
}
a[r] = x;
qs(s, r-1); //對左區間遞歸排序
qs(r+1, e); //對右區間遞歸排序
}
int main()
{
int i, n;
cin>>n;
for(i=0; i<n; i++)
cin>>a[i];
qs(0,n-1);
for(i=0; i<n; i++)
cout<<a[i]<<"";
cout<<endl;
}
posted on 2011-11-22 13:59 More study needed. 閱讀(234) 評論(0) 收藏 舉報
浙公網安備 33010602011771號