快速排序

来源:互联网 发布:overture 5 mac 编辑:程序博客网 时间:2024/05/01 02:13
快速排序算法
void quicksort (sqlist r, int s, int t)
{
     int i=s, j=t;
     if (s<t)
     do
     {
          r[0] =r[s];  /*r[0]暂存选出的数据*/
          while( j>1 && r[j].key >=r[0].key)
               j--;
          if (i<j)
          {
                   r[i]=r[j];
                   i++;
           }
快速排序算法续
       while (i<j && r[i].key <=r[0].key)
               i++;
        if (i<j)
        {
              r[j]=r[i];
               j--;
          }
     }while (i<j);
     r[i]=r[0];
     quicksort(r,s,j-1);  /*递归处理前一部分*/
     quicksort(r,j+1,t);  /*递归处理后一部分*/
}