Chinaunix首页 | 论坛 | 博客
  • 博客访问: 7724303
  • 博文数量: 961
  • 博客积分: 15795
  • 博客等级: 上将
  • 技术积分: 16612
  • 用 户 组: 普通用户
  • 注册时间: 2010-08-07 14:23
文章分类

全部博文(961)

文章存档

2016年(1)

2015年(61)

2014年(41)

2013年(51)

2012年(235)

2011年(391)

2010年(181)

分类: 嵌入式

2011-02-28 08:53:46

  1. /* 冒泡排序 */
  2. #include <stdlib.h>
  3. #include <stdio.h>
  4. #define N 8
  5. void bu_sort(int x[], int n);                 /* 声明冒泡排序函数 */

  6. int main()
  7. {
  8.   int array[N]={ 26, 23, 96, 13, 36, 67, 45, 15};            /* 定义整型数组 */
  9.   int i;
  10.   for(i=0; i<N; i++)                        /* 输出排序前的整数序列 */
  11.     printf("%d ",array[i]);
  12.   printf("\n");
  13.   bu_sort(array, N);                         /* 调用冒泡排序函数 */
  14.   printf("sorted:\n");
  15.   for(i=0; i<N; i++)                        /* 输出排序后的整数序列 */
  16.     printf("%d ", array[i]);
  17.   printf("\n");
  18.   return 0;
  19. }

  20. void bu_sort(int x[], int n)                     /* 定义冒泡排序函数 */
  21. {
  22.   int i, j, t;
  23.   int flag;
  24.   for(i=0; i<n-1; i++)                        /* 进行n-1趟排序 */
  25.   {
  26.     flag = 0;
  27.     for(j=0; j<n-i-1; j++)
  28.     {
  29.       if(x[j] > x[j+1])                     /* 比较相邻的两个数据元素,将较小的放在前面 */
  30.       {
  31.         flag = 1;
  32.         t = x[j];                         /* 交换数据元素 */
  33.         x[j] = x[j+1];
  34.         x[j+1] = t;
  35.       }
  36.     }
  37.     if(0 == flag)                         /* 如果没有数据元素的交换,提前结束排序过程 */
  38.       break;
  39.   }
  40.   return;
  41. }
阅读(1872) | 评论(0) | 转发(2) |
0

上一篇:插入排序

下一篇:二叉树

给主人留下些什么吧!~~