2.冒泡排序.c 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. #include<stdio.h>
  2. #include<stdlib.h>
  3. typedef enum { false, true } bool;
  4. #define N 8
  5. void bubble_sort(int a[],int n);
  6. //一般实现
  7. void bubble_sort(int a[],int n)//n为数组a的元素个数
  8. {
  9. int i,j;
  10. //一定进行N-1轮比较
  11. for(i=0; i<n-1; i++)
  12. {
  13. //每一轮比较前n-1-i个,即已排序好的最后i个不用比较
  14. for(j=0; j<n-1-i; j++)
  15. {
  16. if(a[j] > a[j+1])
  17. {
  18. int temp = a[j];
  19. a[j] = a[j+1];
  20. a[j+1]=temp;
  21. }
  22. }
  23. }
  24. }
  25. //优化实现
  26. void bubble_sort_better(int a[],int n)//n为数组a的元素个数
  27. {
  28. int i,j;
  29. bool isSorted;
  30. int temp;
  31. //最多进行N-1轮比较
  32. for(i=0; i<n-1; i++)
  33. {
  34. isSorted = true;
  35. //每一轮比较前n-1-i个,即已排序好的最后i个不用比较
  36. for(j=0; j<n-1-i; j++)
  37. {
  38. if(a[j] > a[j+1])
  39. {
  40. isSorted = false;
  41. temp = a[j];
  42. a[j] = a[j+1];
  43. a[j+1]=temp;
  44. }
  45. }
  46. if(isSorted) break; //如果没有发生交换,说明数组已经排序好了
  47. }
  48. }
  49. int main()
  50. {
  51. int i;
  52. int num[N] = {89, 38, 11, 78, 96, 44, 19, 25};
  53. bubble_sort(num, N); //或者使用bubble_sort_better(num, N);
  54. for(i=0; i<N; i++)
  55. printf("%d ", num[i]);
  56. printf("\n");
  57. system("pause");
  58. return 0;
  59. }