【C语言实现冒泡排序】

简介: 【C语言实现冒泡排序】

冒泡排序

这次给大家分享一个C语言实现冒泡排序法

冒泡排序其实就是设计一个冒泡排序函数将一个整型数组从小到大排序.

例如一个数组arr[10] = {1,5,2,3,6,7,9,8,4,10},要想数组从小到大排序,就要让数组里面每两个相邻的元素比较,所以我们需要写一个循环进行两两比较;而这个过程又需要循环sz - 1次(sz为数组的元素个数),即冒泡的趟数,让这个比较的过程从头开始.

下面来看代码分析:

void Sort(int arr[],int sz)
  {
    //确定冒泡的趟数
    int i = 0;
    for (i = 0; i < sz - 1; i++)
    {
      int flag = 1;           
      //每一趟冒泡排序--确定比较的次数
      int j = 0;
      for (j = 0; j < sz - 1 - i; j++)
      {
        if (arr[j] > arr[j + 1])
        {
          int tmp = arr[j];
          arr[j] = arr[j + 1];
          arr[j + 1] = tmp;
          flag = 0;     
        }
      }
      if (flag == 1)
        break;
    }
  }

优化代码:给定一个变量flag = 1,1为假设这一趟要排序的数据已经有序;每当进入if条件就代表本趟排序的数据不完全有序,所以会将flag = 0;当某一趟数组已经有序,就不会进入if条件,即本趟数组已经有序,跳出循环,在某个程度上也提高了代码的效率.

int main()
  {
    int arr[] = {452,89,41,22,1,0,369,5,8};
    int sz = sizeof(arr) / sizeof(arr[0]);
    //对arr进行排序,排成升序
    Sort(arr,sz);    //冒泡排序函数
    int i = 0;
    for (i = 0; i < sz; i++)
    {
      printf("%d ",arr[i] );
    }
    return 0;
  }
目录
相关文章
|
7月前
|
C语言
【C语言】拿捏冒泡排序(图解)
【C语言】拿捏冒泡排序(图解)
|
7月前
|
搜索推荐 算法 C语言
C语言:冒泡排序
C语言:冒泡排序
|
7月前
|
Java C语言
用Java(C语言也可以看)实现冒泡排序和折半查找(详细过程图)+逆序数组
用Java(C语言也可以看)实现冒泡排序和折半查找(详细过程图)+逆序数组
76 0
|
2月前
|
算法 搜索推荐 C语言
【C语言】冒泡排序+优化版
【C语言】冒泡排序+优化版
|
2月前
|
C语言
【c语言】qsort函数及泛型冒泡排序的模拟实现
本文介绍了C语言中的`qsort`函数及其背后的回调函数概念。`qsort`函数用于对任意类型的数据进行排序,其核心在于通过函数指针调用用户自定义的比较函数。文章还详细讲解了如何实现一个泛型冒泡排序,包括比较函数、交换函数和排序函数的编写,并展示了完整的代码示例。最后,通过实际运行验证了排序的正确性,展示了泛型编程的优势。
32 0
|
5月前
|
搜索推荐 C语言
C语言冒泡排序(附源码和动态图)
冒泡排序是一种简单的排序算法,其基本思想是通过重复遍历待排序的数列,比较每对相邻元素的值,如果它们的顺序错误(即满足一定的排序条件,如从小到大排序时前一个元素大于后一个元素),就交换它们的位置。这个过程就像水底的气泡一样逐渐向上冒,因此得名“冒泡排序”。
|
6月前
|
算法 搜索推荐 C语言
C语言冒泡排序介绍
C语言冒泡排序介绍
|
6月前
|
C语言
C语言----冒泡排序
C语言----冒泡排序
|
7月前
|
存储 C语言
C语言初阶④(数组)知识点+编程作业(三子棋,冒泡排序)(下)
C语言初阶④(数组)知识点+编程作业(三子棋,冒泡排序)
43 1
|
6月前
|
搜索推荐 前端开发 C语言
C语言探索:冒泡排序的实现与解读
C语言探索:冒泡排序的实现与解读
75 0