经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » C 语言 » 查看文章
冒泡排序,C语言实现
来源:cnblogs  作者:Taltao  时间:2018/12/10 9:44:27  对本文有异议

冒泡排序是一种稳定排序,时间复杂度平均为O(n^2),最好的时间复杂度为O(n),最坏为O(n^2)。

 

排序时每次只比较当前元素与后一个 元素的大小,如果当前元素大于后一个元素,则交换,如此循环直到队尾,每轮排序都可以保证将当前排序下最大的元素送到未排序部分的队尾。

有n个元素要排列,故要执行n次数组的整体大排列。

每次大排列中都要比较当前元素与后一个元素的大小,每轮要比较n-1次,但是因为之前的每一轮都将一个元素放置到了正确的位置,所以无需比较,若设之前累计循环了i次,将i个元素正确地放置在了数组的末尾,所以每轮大排列只需要比较n-1-i次。

 

 

代码如下 

 

冒泡排序:

  1. #include <stdio.h>
  2.  
  3. void bubblingSort(int arr[], int n) {
  4. int i, j, temp;
  5. // 每次将一个元素送到末尾,n个元素,执行n次
  6. for (i = 0; i < n; ++i) {
  7. // 之前的循环已经将i个元素送到末尾,不需要再次比较,故减去,因为跟后一个元素比较,为了避免溢出,故减一
  8. for (j = 0; j < n - i - 1; ++j) {
  9. // 如果当前的元素比后一个元素小,就交换
  10. if (arr[j] > arr[j + 1]) {
  11. temp = arr[j];
  12. arr[j] = arr[j + 1];
  13. arr[j + 1] = temp;
  14. }
  15. }
  16. }
  17. }
  18. int main() {
  19. int i;
  20. int arr[10] = {5, 2, 3, 8, 1, 2, 6, 9, 3, 7};
  21. bubblingSort(arr, 10);
  22. for (i = 0; i < 10; ++i) {
  23. printf("%d ", arr[i]);
  24. }
  25. return 0;
  26. }

 

 从前面的图可以看出,冒泡排序在后几轮实际上已经排好序了,但还是在循环校验。当每次大排列时如果没有一个元素发生交换,数组就已经排好序了,可以终止循环。我们修改一下代码,加上判定元素交换的标志。

 

优化后的冒泡排序:

  1. #include <stdio.h>
  2.  
  3. void bubblingSort(int arr[], int n) {
  4. int i, j, temp;
  5. int flag = 0; // flag用来校验每轮循环有没有移动元素,0为没有移动,1为移动
  6. // 每次将一个元素送到末尾,n个元素,执行n次
  7. for (i = 0; i < n; ++i) {
  8. flag = 0;
  9. // 之前的循环已经将i个元素送到末尾,不需要再次比较,故减去,因为跟后一个元素比较,为了避免溢出,故减一
  10. for (j = 0; j < n - i - 1; ++j) {
  11. // 如果当前的元素比后一个元素小,就交换
  12. if (arr[j] > arr[j + 1]) {
  13. flag = 1; // 有数据交换
  14. temp = arr[j];
  15. arr[j] = arr[j + 1];
  16. arr[j + 1] = temp;
  17. }
  18. }
  19. // 没有数据交换,提前结束
  20. if (flag == 0) {
  21. break;
  22. }
  23. }
  24. }
  25. int main() {
  26. int i;
  27. int arr[10] = {5, 2, 3, 8, 1, 2, 6, 9, 3, 7};
  28. bubblingSort(arr, 10);
  29. for (i = 0; i < 10; ++i) {
  30. printf("%d ", arr[i]);
  31. }
  32. return 0;
  33. }

 

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号