当前位置: 首页 > article >正文

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

冒泡排序 

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

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

//⽅法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)

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


http://www.kler.cn/a/280215.html

相关文章:

  • pg数据库的三种不同数据持久性解读
  • 不可不知的DP协议过往史
  • uniapp中路由的基本使用方法、参数传递方式以及路由拦截与权限控制
  • Nginx: 负载均衡基础配置, 加权轮序, hash算法, ip_hash算法, least_conn算法
  • ensp 中 wlan 的配置过程和示例
  • 2023年最新自适应主题懒人网址导航v3.9php源码
  • Java面试宝典-java基础05
  • KDD2024重磅奖项出炉:“最大奖项”创新奖花落加州大学Lise Getoor,李骏东摘得新星奖
  • 使用密钥文件 SSH 登录服务器:Windows、macOS使用终端或连接工具
  • 【vulhub】Weblogic WLS Core Components 反序列化命令执行漏洞(CVE-2018-2628)
  • 在URL链接中指定浏览器跳转到PDF文件的指定页码
  • 智能手机摄影综评:品牌联名与自建影像品牌的战略分析
  • 【微前端】前端微服务框架对比和技术选型
  • AI搜索“懒人神器”,如何向谷歌和百度发起挑战?
  • 双系统ubuntu引导项丢失如何修复
  • 软件上显示“mfc140.dll丢失”错误信息?那么mfc140.dll丢失该如何修复
  • go国内源设置
  • shallowReactive 与 shallowRef
  • MySQL 官方高可用方案 InnoDB Cluster
  • Ubuntu 16.04下Firefox版本更新