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

冒泡排序

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

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

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)

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

相关推荐
长安er2 分钟前
LeetCode 300/152/416/32 动态规划进阶题型总结(最长递增子序列→最长有效括号)
数据结构·算法·leetcode·动态规划·剪枝
天赐学c语言19 分钟前
12.18 - 有效的括号 && C语言中static的作用
数据结构·c++·算法·leecode
2401_8762213425 分钟前
数据结构-绪论
数据结构
季远迩25 分钟前
LeetCode 热题 100 Python3易懂题解(更新中)
算法·leetcode·哈希算法
CoovallyAIHub27 分钟前
从“模仿”到“进化”!华科&小米开源MindDrive:在线强化学习重塑「语言-动作」闭环驾驶
深度学习·算法·计算机视觉
别动哪条鱼27 分钟前
SDL 函数对各对象缓冲区的影响
网络·数据结构·ffmpeg
xie_pin_an39 分钟前
C 语言排序算法全解析:从原理到实战,附性能对比
c语言·算法·排序算法
CoovallyAIHub41 分钟前
SAM 真的开始「分割一切」,从图像到声音,Meta 开源 SAM Audio
深度学习·算法·计算机视觉
三斗米44 分钟前
从思维链到思维树:一步步解锁大语言模型的推理能力
算法
jianfeng_zhu1 小时前
添加逗号问题
数据结构