C程序 递归小例子 快速排序

从执行速度来讲,下列版本的快速排序可能不是最快的,但是它是最简单的算法之一。在每次划分子集时,该算法总是选取各个子数组的中间元素,(作为划分子集的基准)。

 

/* qsort:  以递增顺序对v[left]...v[right]进行排序 */
   void qsort(int v[], int left, int right)
   {
       int i, last;
       void swap(int v[], int i, int j);
	     if (left >= right) /* 若数组包含的元素数少于两个 */
           return;        /* 则不执行任何操作 */
       swap(v, left, (left + right)/2); /* 将划分子集的元素 */
       last = left;                     /* 移动到v[0] */
       for (i = left + 1; i <= right; i++)  /* 划分子集 */
           if (v[i] < v[left])
               swap(v, ++last, i);
       swap(v, left, last);            /* 恢复划分子集的元素(很可能不再是之前的位置,因为此时last可能不等于(left+right)/2) */
       qsort(v, left, last-1);
       qsort(v, last+1, right);
   }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值