快速排序

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;
}

递归并不节省存储器的开销,因为递归调用过程中必须在某个地方维护一个存储处理值的“栈”。
 

你可能感兴趣的:(快速排序)