Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2118570
  • 博文数量: 438
  • 博客积分: 3871
  • 博客等级: 中校
  • 技术积分: 6075
  • 用 户 组: 普通用户
  • 注册时间: 2011-09-10 00:11
个人简介

邮箱: wangcong02345@163.com

文章分类

全部博文(438)

文章存档

2017年(15)

2016年(119)

2015年(91)

2014年(62)

2013年(56)

2012年(79)

2011年(16)

分类: LINUX

2016-07-25 11:13:33

1. 冒泡排序
由小到大排序的过程
第一趟相当于找到最小值并放在首位,
    第1个数与剩下的n-1个数比较,若有比第1个数小的就交换,让第1个数始终存本趟最小的数
第二趟相当于找到次小值,并放在第2的位置上
      第2个数与剩下的n-2个数比较,若有比第2个数小的就交换,让第2个数始终存本趟最小的数
以此类推
1.2 代码
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #define dbmsg(fmt, args ...) printf("%s:%s[%d]: "fmt"\n", __FILE__,__FUNCTION__, __LINE__,##args)
  4. #define SWAP(x,y) (x=(x)+(y),y=(x)-(y),x=(x)-(y))

  5. int dump_arry(int* arr, int len)
  6. {
  7.     int i;
  8.     for(i=0; i<len; i++)
  9.     {
  10.         //printf("%d=%d ", i, arr[i]);
  11.         printf("%d ", arr[i]);
  12.     }
  13.     printf("\n");
  14.     return 0;
  15. }
  16. //由小到大进行排序
  17. int bubble_sort(int* arr, int len)
  18. {
  19.     int i, j;
  20.     for(i=0; i<len; i++)
  21.     {
  22.         dbmsg("i=%d",i);
  23.         for(j=i+1; j<len; j++)
  24.         {
  25.             if(arr[j] < arr[i])         //arr[i]存放最小的数,如果后面的数比arr[i]还小
  26.                 SWAP(arr[j], arr[i]);   //则交换,让arr[i]始终存放这一趟中最小的数
  27.         }
  28.         dump_arry(arr, len);
  29.     }
  30. }

  31. int main ( int argc, char *argv[] )
  32. {
  33.     //int arr[] = {49, 38, 65, 97, 76, 13, 27, 49};
  34.     int arr[] = {49, 38, 65, 97, 76, 13, 27, 49, 55, 4};
  35.     int len = sizeof(arr)/sizeof(int);
  36.     dbmsg("len=%d", len);
  37.     dbmsg("before bubble:");
  38.     dump_arry(arr, len);

  39.     bubble_sort(arr, len);    //由小到大进行排序

  40.     dbmsg("after bubble:");
  41.     dump_arry(arr, len);
  42.     return EXIT_SUCCESS;
  43. }
1.3 运行结果
  1. bubble.c:main[38]: len=10
  2. bubble.c:main[39]: before bubble:
  3. 49 38 65 97 76 13 27 49 55 4
  4. bubble.c:bubble_sort[23]: i=0
  5. 4 49 65 97 76 38 27 49 55 13            -->第1趟把最小值4放在了最前面,同时n-1的数也有变化
  6. bubble.c:bubble_sort[23]: i=1
  7. 4 13 65 97 76 49 38 49 55 27            -->第2趟把次小值133放在了本趟的是前面,同时n-2的数也有变化
  8. bubble.c:bubble_sort[23]: i=2
  9. 4 13 27 97 76 65 49 49 55 38
  10. bubble.c:bubble_sort[23]: i=3
  11. 4 13 27 38 97 76 65 49 55 49
  12. bubble.c:bubble_sort[23]: i=4
  13. 4 13 27 38 49 97 76 65 55 49
  14. bubble.c:bubble_sort[23]: i=5
  15. 4 13 27 38 49 49 97 76 65 55
  16. bubble.c:bubble_sort[23]: i=6
  17. 4 13 27 38 49 49 55 97 76 65
  18. bubble.c:bubble_sort[23]: i=7
  19. 4 13 27 38 49 49 55 65 97 76
  20. bubble.c:bubble_sort[23]: i=8
  21. 4 13 27 38 49 49 55 65 76 97
  22. bubble.c:bubble_sort[23]: i=9
  23. 4 13 27 38 49 49 55 65 76 97
  24. bubble.c:main[42]: after bubble:
  25. 4 13 27 38 49 49 55 65 76 97
1.4 性能
O(n2)
1.5 代码打包
bubble.rar  (下载后改名为bubble.tar.gz)

2.1 改进
上述算法有一个问题:如果是己排序好的数据,还要一个个的比较
所以为了避免这样,加了一个标志位,当检测到己排好序之后就直接跳出循环
如果这趟没有数据交换说明己排序好

2.2 代码
代码插入不了,格式很难看
#include
#include
#define dbmsg(fmt, args ...) printf("%s:%s[%d]: "fmt"\n", __FILE__,__FUNCTION__, __LINE__,##args)
#define SWAP(x,y) (x=(x)+(y),y=(x)-(y),x=(x)-(y))


int dump_arry(int* arr, int len)
{
    int i;
    for(i=0; i     {
        //printf("%d=%d ", i, arr[i]);
        printf("%d  ", arr[i]);
    }
    printf("\n");
    return 0;
}


int bubble_sort(int* arr, int len)
{
    int i, j;
    int flag;
    for(i=0; i     {
        flag = 1;
        dbmsg("arr[%d]=%d",i, arr[i]);
        for(j=i+1; j         {
            if(arr[j] < arr[i])
            {
                flag = 0;
                SWAP(arr[j], arr[i]);
            }
            dbmsg("arr[%d]=%d",i, arr[i]);
        }
        dump_arry(arr, len);
        if(1 == flag)
            break;
    }
}


int main ( int argc, char *argv[] )
{
    //int arr[] = {49, 38, 65, 97, 76, 13, 27, 49};
    //int arr[] = {49, 38, 65, 97, 76, 13, 27, 49, 55, 4};
    int arr[] = {4, 13, 27, 38, 49, 49, 55, 65, 76, 97};
    int len = sizeof(arr)/sizeof(int);
    dbmsg("len=%d", len);
    dbmsg("before bubble:");
    dump_arry(arr, len);
    bubble_sort(arr, len);
    dbmsg("after bubble:");
    dump_arry(arr, len);
    return EXIT_SUCCESS;
}
代码插入不了,格式很难看


2.3 代码打包
bubble2.rar(下载后改名为bubble2.tar.gz)




阅读(1371) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~