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

          快速排序的基本思想是:通过一趟数据比较和交换,将要排序的数据分成前后两部分,其中一部分的数据都比另外一部分的数据都要小,然后,再按这种方法对分开的两部分数据分别进行一次快速排序,依次执行下去,直到整个序列有序为止。
      例如,有无序序列{a1,a2,a3,a4,……,an},使用快速排序的过程为:
      首先,任选一个数据(通常选第一个元素数据a1)作为关键数据。然后,将所有比它小的元素都交换到它前面,所有比它大的元素都交换到它后面,执行这样一次比较和交换过程称为一趟快速排序。一趟快速排序的算法描述如下:
    1)设置两个变量i和j,排序初始时设置初始值为:i=1,j=n-1;
    2)取第一个元素a1作为关键数据,赋值给临时变量KeyTemp,令KeyTemp = a1;
    3)从j开始逐渐向序列前面搜索,即执行j--操作,依次与KeyTemp比较,直到找到第一个小于KeyTemp的元素为止,然后将找到的元素与KeyTemp交换;
    4)从i开始向序列后面搜索,即执行i++操作,依次与KeyTemp比较,直到找到第一个大于KeyTemp的元素,然后将找到的元素与KeyTemp交换;
    5)重复上述第3、4步,直到i = = j; 
  • 相关阅读:
    SAP BI 常用TCODE
    ABAP Table Control
    Smartforms 设置纸张打印格式
    SAP库存历史库存表更新逻辑 (转)
    ABAP 调用远程rfc
    php 随机生成数字字母组合
    php错误提示 open_basedir restriction in effect 解决
    MySQL Errno : 1062 错误修复
    mysql数据库允许远程连接
    httpd.conf文件与.htaccess文件的对比
  • 原文地址:https://www.cnblogs.com/hanjun/p/2798753.html
Copyright © 2011-2022 走看看