1, 递归实现的方法:
#include <stdio.h>
#define LEN 10
void qsort(int, int, int);
main()
{
int i;
int a[LEN] = {3,2,5,6,7,1,2,8,9,4};
qsort(a, 0, LEN-1);
for(i=0;i<LEN;i++)
printf("%d, ", a[i]);
printf("\n");
}
void qsort(int v[], int l, int r)
{
int i, p;
void swap(int v[], int i, int j);
if(l >= r)/*Do nothing*/
return;
//这里,默认地将以数组的中间元素为支点元素
//所以需要提前处理一下,将中间元素与第一个元素互换
//实际上,完全可以以第一个元素为支点元素进行处理,数据结构的书上就是这样做的。
swap(v, l, (r+l)/2);
p = l;//给待移动的处理下标p赋初值,指向第一个元素。
//要从支点元素后的第一个元素开始执行比较,所以i=l+1
for(i=l+1;i<=r;i++)
{
//遍历数组元素,并且与支点元素(此刻的支点元素在最左端)比较
if(v[i] < v[l])
//如果小于支点元素,则与处理下标P的下一个元素互换
//第一次互换时,即v[i]与v[++p]=="v[l]后的第一个元素"互换
swap(v, ++p, i);
swap(v, l, p);//保存支点元素,即再将支点元素换回到p所执的位置,如此可以使p前所有的元素都小于v[l].
//接下来,是分别对各个分段进行递归执行
qsort(v, l, p-1);
qsort(v, p+1, r);
}
}
void swap(int v[], int i, int j)
{
int temp;
temp = v[i];
v[i] = v[j];
v[j] = temp;
}
递归并不节省存储器的开销,因为递归调用过程中必须在某个地方维护一个存储处理值的“栈”。