冒泡排序(C语言详解)

**原理:**从左到右一次比较,如果左侧数字比右侧数字大(小),则两数交换,否则比较下一 组数字,每一次大循环比较可以将乱序的最右侧数字改为最大(最小),每一次小循环的比 较次数相对于前一次要减一


动态用例:

升序排序代码详解:

复制代码
void bubble_sort (int arr[],int sz)   //将数组和元素个数传过来
{
  for(int i=0;i<sz-1;i++)   //每次大循环可以确定乱序最后一个数字,最多需要sz-1次循环
  {
    int tmp=0;
      for(int j=0;j<sz-1-i;j++)//每次小循环,因为已经确定最后的i个元素,剩下需要比较的元素个数就为sz-i,而需要比较的次数就为sz-1-i
      {
        if(arr[j]>arr[j+1])//相邻两个数比较,如过前一个数比后一个数大就交换
       {
int t=arr[j];
arr[j]=arr[j+1];
arr[j+1]=t;
tmp=1;
       }
      }
if(tmp==0)
break;
  }
}

降序排序代码详解:

复制代码
void bubble_sort (int arr[],int sz)   //将数组和元素个数传过来
{
  for(int i=0;i<sz-1;i++)   //每次大循环可以确定乱序最后一个数字,最多需要sz-1次循环
  {
    int tmp=0;
      for(int j=0;j<sz-1-i;j++)//每次小循环,因为已经确定最后的i个元素,剩下需要比较的元素个数就为sz-i,而需要比较的次数就为sz-1-i
      {
        if(arr[j]<arr[j+1])//相邻两个数比较,如过前一个数比后一个数小就交换
       {
int t=arr[j];
arr[j]=arr[j+1];
arr[j+1]=t;
tmp=1;
       }
      }
if(tmp==0)
break;
  }
}

两者排序方式唯一的区别:

1.升序排序:如果前一个数比后一个数大,二者就交换,所以用>

2.降序排序:如果前一个数比后一个数大,二者就交换,所以用<

tmp的作用:

每一次大循环,我们都将tmp设置为0,在每一次小循环里面,如果两个数进行了交换,我们就将tmp改为1,出这次大循环判断一下tmp是否为0,如果为0,那么本次循环没有进行交换,也就是数组已经排好序,直接退出大循环,否则继续进行循环。

相关推荐
会开花的二叉树6 分钟前
c语言贪吃蛇游戏开发
c语言·开发语言
韩立学长13 分钟前
【开题答辩实录分享】以《C#大型超市商品上架调配管理系统的设计与实现》为例进行答辩实录分享
开发语言·c#
十重幻想25 分钟前
PTA6-4 使用函数统计指定数字的个数(C)
c语言·c++·算法
夜月yeyue26 分钟前
ART 加速器、流水线与指令预测的关系详解
linux·服务器·c语言·单片机·嵌入式硬件·性能优化·嵌入式高阶技巧
迎風吹頭髮44 分钟前
UNIX下C语言编程与实践36-UNIX 时钟:系统时间、高分辨率时间与日历时间的转换与使用
服务器·c语言·unix
Yupureki1 小时前
从零开始的C++学习生活 5:内存管理和模板初阶
c语言·c++·学习·visual studio
tao3556671 小时前
【Python刷力扣hot100】49. Group Anagrams
开发语言·python·leetcode
龙腾AI白云1 小时前
大模型-扩散模型(Diffusion Model)原理讲解(4)
开发语言
爱吃小胖橘2 小时前
Lua语法(2)
开发语言·unity·lua
_Power_Y2 小时前
SSM面试题学习
java·开发语言·学习