zoukankan      html  css  js  c++  java
  • 快速排序算法

     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,

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

    采用的是分治法的思想

  • 相关阅读:
    解决ORACLE存储过程锁定的问题
    #{propName,attr1=val1,attr2=val2}
    集成confluence与jira
    jira4.1.1安装
    Mac OS X 10.6下安装MySQL 5.1.45
    JIRA+MySQL配置
    xcode4.5 iOS6 cocos2dx 横屏解决方案
    gSoap
    Jira5.0.2安装及破解
    MFC中显示cocos2dx
  • 原文地址:https://www.cnblogs.com/wuyinghong/p/3452967.html
Copyright © 2011-2022 走看看