了解冒泡排序,并写出一个函数进行排序,拍成升序

简介: 了解冒泡排序,并写出一个函数进行排序,拍成升序

冒泡排序:它的基本思想是对所有相邻记录的关键字值进行比效,如果是逆顺(a[j]>a[j+1]),则将其交换,最终达到有序化 。


image.png


当有n个数时,会进行n-1趟冒泡排序,第一趟排n-1次,第二趟排n-2次……


n-1趟排1次


#include <stdio.h>
void bubble_sort(int arr[], int sz)
{
  int i = 0;
  for (i = 0; i < sz-1; i++)
  {
    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;
      }
    }
  }
}
int main()
{
  int i = 0;
  int arr[] = { 9,8,7,6,5,4,3,2,1,0 };
  int sz = sizeof(arr) / sizeof(arr[0]);
  bubble_sort(arr,sz);
  for (i = 0; i < sz; i++)
  {
    printf("%d ",arr[i]);
  }
  return 0;
}

image.png


优化代码:


void bubble_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;
      }
    }
  }
}
相关文章
|
6月前
|
JavaScript 前端开发
sort函数排序
sort函数排序
53 0
sort函数排序
|
6月前
|
算法 搜索推荐
排序——选择排序
排序——选择排序
58 0
|
算法 搜索推荐 索引
排序篇(二)----选择排序
排序篇(二)----选择排序
31 0
LetCode第912题 排序数组之冒泡排序
依次比较相邻的两du个数,将小数放在前面zhi,大数放在后面。即首先比较第dao1个和第2个数,将小数放前,大数放后。然后比较第2个数和第3个数,将小数放前,大数放后,如此继续,直至比较最后两个数,将小数放前,大数放后。重复以上过程,仍从第一对数开始比较(因为可能由于第2个数和第3个数的交换,使得第1个数不再大于第2个数),将小数放前,大数放后,一直比较到最小数前的一对相邻数,将小数放前,大数放后,第二趟结束,在倒数第二个数中得到一个新的最小数。如此下去,直至最终完成排序。
49 0
LetCode第912题 排序数组之冒泡排序
|
算法 搜索推荐
排序——冒泡排序
这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端(升序或降序排列),就如同碳酸饮料中二氧化碳的气泡最终会上浮到顶端一样,故名“冒泡排序”。
|
搜索推荐
排序(2)之选择排序
继插入排序后,今天小编就给大家另一个模块,选择排序的学习,那么话不多说,我们直接进入正题。
114 0
|
算法
两个升序链表合并成一个降序链表的时间复杂度
两个升序链表合并成一个降序链表的时间复杂度
420 6
两个升序链表合并成一个降序链表的时间复杂度
|
索引
掌握常见的几种排序-选择排序
选择排序是一种简单的排序,时间复杂度是O(n^2),在未排序的数组中找到最小的那个数字,然后将其放到起始位置,从剩下未排序的数据中继续寻找最小的元素,将其放到已排序的末尾,以此类推,直到所有元素排序结束为止。
117 0
掌握常见的几种排序-选择排序
|
算法
【排序】归并类排序—归并排序(逆序数问题)
在排序中,我们可能大部分更熟悉冒泡排序、快排之类。对归并排序可能比较陌生。然而事实上归并排序也是一种稳定的排序,时间复杂度为O(nlogn).
112 0
【排序】归并类排序—归并排序(逆序数问题)
|
算法
排序——快速排序
排序——快速排序
118 0
排序——快速排序