打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
C语言冒泡排序算法及代码

冒泡排序是排序算法的一种,思路清晰,代码简洁,常被用在大学生计算机课程中。

“冒泡”这个名字的由来是因为越大的元素会经由交换慢慢“浮”到数列的顶端,故名。

这里以从小到大排序为例进行讲解。

基本思想及举例说明

冒泡排序的基本思想就是不断比较相邻的两个数,让较大的元素不断地往后移。经过一轮比较,就选出最大的数;经过第2轮比较,就选出次大的数,以此类推。

下面以对 3 2 4 1 进行冒泡排序说明。

第一轮 排序过程
3 2 4 1 (最初)
2 3 4 2 (比较3和2,交换)
2 3 4 1 (比较3和4,不交换)
2 3 1 4 (比较4和1,交换)
第一轮结束,最大的数4已经在最后面,因此第二轮排序只需要对前面三个数进行再比较。

第二轮 排序过程
2 3 1 4 (第一轮排序结果)
2 3 1 4 (比较2和3,不交换)
2 1 3 4 (比较3和1,交换
第二轮结束,第二大的数已经排在倒数第二个位置,所以第三轮只需要比较前两个元素。

第三轮 排序过程
2 1 3 4 (第二轮排序结果)
1 2 3 4 (比较2和1,交换)
至此,排序结束。

算法总结及实现

对于具有N个元素的数组R[n],进行最多N-1轮比较;

第一轮,逐个比较(R[1], R[2]), (R[2], R[3]), (R[3], R[4]), ……. (R[N-1], R[N]) ; 最大的元素会被移动到R[N]上。

第二轮,逐个比较(R[1], R[2]), (R[2], R[3]), (R[3], R[4]), ……. (R[N-2], R[N-1]);第二大元素会被移动到R[N-1]上。

。。。。
以此类推,直到整个数组从小到大排序。

下面给出了冒泡排序的一般实现和优化实现。一般实现是教科书里常见的实现方法,无论数组是否排序好了,都会进行N-1轮比较; 而优化实现,在数组已经排序好的情况下,会提前退出比较,减小了算法的时间复杂度。
  1. #include
  2. #include
  3. #define N 8
  4. void bubble_sort(int a[],int n);
  5. //一般实现
  6. void bubble_sort(int a[],int n)//n为数组a的元素个数
  7. {
  8. //一定进行N-1轮比较
  9. for(int i=0; in-1; i++)
  10. {
  11. //每一轮比较前n-1-i个,即已排序好的最后i个不用比较
  12. for(int j=0; jn-1-i; j++)
  13. {
  14. if(a[j] > a[j+1])
  15. {
  16. int temp = a[j];
  17. a[j] = a[j+1];
  18. a[j+1]=temp;
  19. }
  20. }
  21. }
  22. }
  23. //优化实现
  24. void bubble_sort_better(int a[],int n)//n为数组a的元素个数
  25. {
  26. //最多进行N-1轮比较
  27. for(int i=0; in-1; i++)
  28. {
  29. bool isSorted = true;
  30. //每一轮比较前n-1-i个,即已排序好的最后i个不用比较
  31. for(int j=0; jn-1-i; j++)
  32. {
  33. if(a[j] > a[j+1])
  34. {
  35. isSorted = false;
  36. int temp = a[j];
  37. a[j] = a[j+1];
  38. a[j+1]=temp;
  39. }
  40. }
  41. if(isSorted) break; //如果没有发生交换,说明数组已经排序好了
  42. }
  43. }
  44. int main()
  45. {
  46. int num[N] = {89, 38, 11, 78, 96, 44, 19, 25};
  47. bubble_sort(num, N); //或者使用bubble_sort_better(num, N);
  48. for(int i=0; iN; i++)
  49. printf('%d ', num[i]);
  50. printf('\n');
  51. system('pause');
  52. return 0;
  53. }

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
Java中的经典算法之冒泡排序(Bubble Sort)
排序算法复习(Java实现):插入,冒泡,选择,Shell,快速排序
详解冒泡排序
常用排序算法的C语言版实现示例整理
c语言必会排序算法集(含代码解析)
算法中的各种排序以及查找时间复杂度
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服