Chinaunix首页 | 论坛 | 博客
  • 博客访问: 209380
  • 博文数量: 33
  • 博客积分: 1241
  • 博客等级: 中尉
  • 技术积分: 330
  • 用 户 组: 普通用户
  • 注册时间: 2007-01-20 16:34
个人简介

..

文章分类

全部博文(33)

文章存档

2012年(1)

2011年(8)

2010年(8)

2009年(4)

2007年(12)

我的朋友

分类: C/C++

2011-11-23 17:30:53

快速排序(Quicksort)是对冒泡排序的一种改进。由C. A. R. Hoare在1962年提出。它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。

设要排序的数组是A[0]……A[N-1],首先任意选取一个数据(通常选用第一个数据)作为关键数据,然后将所有比它小的数都放到它前面,所有比它大的数都放到它后面,这个过程称为一趟快速排序。值得注意的是,快速排序不是一种稳定的排序算法,也就是说,多个相同的值的相对位置也许会在算法结束时产生变动。

  1. #include <stdio.h>

  2. void QuickSort(int e[], int first, int end)
  3. {
  4.     int i=first, j=end, tmp=e[first];
  5.     while(i<j) {
  6.         while(i<j && e[j]>=tmp)
  7.             j--;
  8.         e[i]=e[j];
  9.         while(i<j && e[i]<=tmp)
  10.             i++;
  11.         e[j]=e[i];
  12.     }
  13.     e[i]=tmp;
  14.     if(end>first){
  15.         QuickSort(e,first,i-1);
  16.         QuickSort(e,i+1,end);
  17.     }
  18. }
  19. int main(void)
  20. {
  21.     int arr[] = {49, 38, 65, 97, 76, 13, 27, 49};
  22.     int len = sizeof(arr)/sizeof(*arr);
  23.     int i;
  24.     printf("before sort\n");
  25.     for(i=0; i<len; i++)
  26.         printf("%d ", arr[i]);
  27.     printf("\n");

  28.     QuickSort(arr, 0, len-1);

  29.     printf("after sorted\n");
  30.     for(i=0; i<len; i++)
  31.         printf("%d ", arr[i]);
  32.     printf("\n");
  33.     return 0;
  34. }
阅读(3312) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~