快速排序算法

 void qsort(int v[], int left, int right)
  {
  int j, last;
  if (left >= right)                             /* 若数组包含的元素个数少于两个 */
  return;                                         /* 则不执行任何操作 */
  swap(v, left, (left + right)/2);          /* 将划分子集的元素移动到V[0] */
  last=left;                                      /* 用last记录中比关键字小间的最右位置*/
  for (j = left+1; j <= right; j++)      /* 划分子集 */
  {
  if (v[j] < v[left])
  {
  swap(v, ++last, j); 
  }
  }
  /*通过上述过程会形成 关键字(中left所在位置) 小小小...(last所在位置)大大大大(最后)*/
  swap(v, left, last);                       /* 恢复划分的元素 */
  /*小小。。。。关键字大大大大*/
  qsort(v, left, last-1);
  qsort(v, last+1, right);
  }

/**************************************************************************/

两个for循环,

一个用来控制比较的趟数,一个用来每趟比较的次数

连个指针i,j,

一个指向数组的头,一个指向数组的尾。

采用的是分治法的思想

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值