C语言常用排序全解(二)

2014-11-23 21:34:14 · 作者: · 浏览: 54

  {

  *(x+k+h) = *(x+k);

  }

  *(x+k+h) = t;

  }

  }

  }

  /*

  ================================================

  功能:快速排序

  输入:数组名称(也就是数组首地址)、数组中起止元素的下标

  ================================================

  */

  /*

  ====================================================

  算法思想简单描述:

  快速排序是对冒泡排序的一种本质改进。它的基本思想是通过一趟扫描后,使得排序序列的长度能大幅度地减少。在冒泡排序中,一次扫描只能确保最大数值的数移到正确位置,而待排序序列的长度可能只减少1。快速排序通过一趟扫描,就能确保某个数(以它为基准点吧)的左边各数都比它小,右边各数都比它大。然后又用同样的方法处理它左右两边的数,直到基准点的左右只有一个元素为止。它是由C.A.R.Hoare于1962年提出的。

  显然快速排序可以用递归实现,当然也可以用栈化解递归实现。下面的函数是用递归实现的,有兴趣的朋友可以改成非递归的。

  快速排序是不稳定的。最理想情况算法时间复杂度O(nlog2n),最坏O(n2)

  =====================================================

  */

  void quick_sort(int *x, int low, int high)

  {

  int i, j, t;

  if (low < high) /*要排序的元素起止下标,保证小的放在左边,大的放在右边。这里以下标为low的元素为基准点*/

  {

  i = low;

  j = high;

  t = *(x+low); /*暂存基准点的数*/

  while (i

  {

  while (it) /*在右边的只要比