Chinaunix首页 | 论坛 | 博客
  • 博客访问: 25270
  • 博文数量: 14
  • 博客积分: 600
  • 博客等级: 中士
  • 技术积分: 165
  • 用 户 组: 普通用户
  • 注册时间: 2008-11-05 11:28
文章分类

全部博文(14)

文章存档

2011年(1)

2009年(3)

2008年(10)

我的朋友

分类: C/C++

2009-02-16 16:29:41

#include
#include

void quick_sort(int array[],int first, int last)
{
    int temp, low, high, separator;
    low = first;
    high = last;
    separator = array[(first + last) / 2];
    do
      {
        while(array[low] < separator)
            low++;
        while(array[high] > separator)
            high--;
        if (low <= high)
          {
            temp = array[low];
            array[low++] = array[high];
            array[high--] = temp;
          }
      }while(low <= high);
    if (first < high)
      quick_sort(array, first, high);
    if (low < last)
      quick_sort(array, low, last);
}
int main(void)
{
    int values[150], i;
    for (i = 0; i < 150; i++)
      values[i] = rand() % 1000;
    
    quick_sort(values,0,149);
    for (i = 0; i < 149; i++)
    printf("%d ",values[i]);
    return 0;
}
阅读(484) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~