快速排序是对冒泡排序的一种改进。它的基本思想是:通过一躺排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一不部分的所有数据都要小,然后再按次方法对这两部分数据分别进行快速排序,整个排序过程可以递归或者非递归进行,以此达到整个数据变成有序序列。
快速排序的递归算法:
void qsort(int a[],int left,int right)
{
int pivot,l,r,temp;
l = left;
r = right;
pivot = a[(left+right)/2]; //取中位值作为分界值
while(l<r)
{
while(a[l] < pivot) ++l;
while(a[r] > pivot) --r;
if(l>=r) break;
temp = a[l];
a[l] = a[r];
a[r] = temp;
++l;
--r;
}
if(l==r) l++;
if(left < r) qsort(a, left,l-1);
if(l < right) qsort(a,r+1,right);
}
快速排序的非递归算法
#include <stack>
using namespace std;
template <class T>
int partition(T a[],int low,int high)
{
T v=a[low];
while(low<high)
{
while(low<high && a[high]>=v) high--;
a[low]=a[high];
while(low<high && a[low]<=v) low++;
a[high]=a[low];
}
a[low]=v;
return low;
}
void QuickSort(T a[],int p,int q)
{
stack<int> st;
int j;
do{
while(p<q)
{
j=partition(a,p,q);
if( (j-p)<(q-j) )
{
st.push(j+1);
st.push(q);
q=j-1;
}
else
{
st.push(p);
st.push(j-1);
p=j+1;
}
}
if(st.empty()) return;
q=st.top();st.pop();
p=st.top();st.pop();
//cout<<endl<<"p:"<<p<<" ";
//cout<<"q:"<<q<<endl;
}while(1);
}
void main()
{
//int a[7]={7,6,5,4,3,2,1};
//int a[7]={1,2,3,4,5,6,7};
int a[7]={3,5,2,3,66,225,1};
for(int i=0;i<7;i++)
cout<<a[i]<<" ";
QuickSort(a,0,6);
cout<<endl;
for(int i=0;i<7;i++)
cout<<a[i]<<" ";
}