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

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

冒泡排序:它的基本思想是对所有相邻记录的关键字值进行比效,如果是逆顺(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;
      }
    }
  }
}
相关文章
|
8月前
|
JavaScript 前端开发
sort函数排序
sort函数排序
75 0
sort函数排序
|
8月前
|
算法 搜索推荐
排序——选择排序
排序——选择排序
79 0
|
8月前
|
搜索推荐 算法 Shell
排序——插入排序
排序——插入排序
55 0
LetCode第912题 排序数组之冒泡排序
依次比较相邻的两du个数,将小数放在前面zhi,大数放在后面。即首先比较第dao1个和第2个数,将小数放前,大数放后。然后比较第2个数和第3个数,将小数放前,大数放后,如此继续,直至比较最后两个数,将小数放前,大数放后。重复以上过程,仍从第一对数开始比较(因为可能由于第2个数和第3个数的交换,使得第1个数不再大于第2个数),将小数放前,大数放后,一直比较到最小数前的一对相邻数,将小数放前,大数放后,第二趟结束,在倒数第二个数中得到一个新的最小数。如此下去,直至最终完成排序。
63 0
LetCode第912题 排序数组之冒泡排序
|
算法 搜索推荐 索引
排序篇(二)----选择排序
排序篇(二)----选择排序
41 0
|
存储 搜索推荐 测试技术
排序篇(一)----插入排序
排序篇(一)----插入排序
58 0
|
算法 搜索推荐
排序——冒泡排序
这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端(升序或降序排列),就如同碳酸饮料中二氧化碳的气泡最终会上浮到顶端一样,故名“冒泡排序”。
|
搜索推荐
排序(2)之选择排序
继插入排序后,今天小编就给大家另一个模块,选择排序的学习,那么话不多说,我们直接进入正题。
122 0
|
存储 搜索推荐 测试技术
排序(1)之插入排序
从今天小编就开始给大家介绍排序的内容,对于排序内容我们一共分,插入,选择,交换,归并这几个大类,那么今天小编给大家带来的就是插入排序
109 0
|
算法
两个升序链表合并成一个降序链表的时间复杂度
两个升序链表合并成一个降序链表的时间复杂度
442 6
两个升序链表合并成一个降序链表的时间复杂度