冒泡排序详细说明(内含动态演示图)

冒泡排序

冒泡排序的核⼼思想就是:两两相邻的元素进行比较。冒泡排序是⼀种最基础的交换排序。

之所以叫做冒泡排序,因为每⼀个元素都可以像小⽓泡⼀样,根据⾃⾝⼤⼩⼀点⼀点向数组的⼀侧移动。

cpp 复制代码
//⽅法1 
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-i-1; j++)
         {
             if(arr[j] > arr[j+1])
             {    
                 int tmp = arr[j];
                 arr[j] = arr[j+1];
                 arr[j+1] = tmp;
             }
         }
     }
}
int main()
{
     int arr[] = {3,1,7,5,8,9,0,2,4,6};
     int sz = sizeof(arr)/sizeof(arr[0]);
     bubble_sort(arr, sz);
     for(i=0; i<sz; i++)
     {
         printf("%d ", arr[i]);
     }
     return 0;
}

//⽅法2 - 优化 
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-i-1; j++)
         {
             if(arr[j] > arr[j+1])
             {
                 flag = 0;//发⽣交换就说明,⽆序 
                 int tmp = arr[j];
                 arr[j] = arr[j+1];
                 arr[j+1] = tmp;
             }
         }
     if(flag == 1)//这⼀趟没交换就说明已经有序,后续⽆序排序了 
         break;
     }
}
int main()
{
     int arr[] = {3,1,7,5,8,9,0,2,4,6};
     int sz = sizeof(arr)/sizeof(arr[0]);
     bubble_sort(arr, sz);
     for(i=0; i<sz; i++)
     {
         printf("%d ", arr[i]);
     }
     return 0;
}

冒泡排序的特性总结

• 时间复杂度:O(N^2)

• 空间复杂度:O(1)

冒泡排序的效率太低,一般企业当中不会使用,只有教学意义。

相关推荐
qq_4308558817 小时前
线性代数第一章第一课: 二阶三阶行列式
线性代数·算法·矩阵
FMRbpm17 小时前
链表实现栈:具体函数实现
数据结构·c++·新手入门
量子炒饭大师17 小时前
Cyber骇客的数据链路重构 ——【初阶数据结构与算法】线性表之单链表
c语言·数据结构·c++·windows·git·链表·github
星轨初途17 小时前
C++的条件判断与循环及数组(算法竞赛类)
开发语言·c++·经验分享·笔记·算法
Keep__Fighting17 小时前
【机器学习:线性回归】
人工智能·python·算法·机器学习·支持向量机·线性回归·scikit-learn
for_ever_love__17 小时前
引用的基本用法及本质
算法
MadPrinter18 小时前
FindQC 实战 (一):基于 SerpApi 的电商高质量图片自动化筛选算法初探
运维·python·算法·自动化
小毅&Nora18 小时前
【人工智能】【深度学习】 ③ DDPM核心算法介绍:从噪声到图像的魔法
人工智能·深度学习·算法
h***015418 小时前
图解缓存淘汰算法 LRU、LFU | 最近最少使用、最不经常使用算法 | go语言实现
算法·缓存·golang