冒泡排序

简介: 冒泡排序

bubbleSort

比较相邻的元素。如果第一个比第二个大,就交换他们两个。

对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。这步做完后,最后的元素会是最大的数。

针对所有的元素重复以上的步骤,除了最后一个。

持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端(升序或降序排列),就如同碳酸饮料中二氧化碳的气泡最终会上浮到顶端一样,故名“冒泡排序”。

算法步骤

第一版

template<typenameT>

voidbubbleSort(Tarr[],intn){

   //在当前数组上,每次都是从第一个元素开始比较,直到没有元素交换,flag仍为true,排序完成

   for(inti=0;i<n;i++){

       boolflag=true;

       //循环一次,比较总数就减少一次

       for(intj=1;j<n-i;j++){

           if(arr[j-1]>arr[j]){

               swap(arr[j-1],arr[j]);

               flag=false;

           }

       }

       if(flag) break;

   }

   return;

}

template<typenameT>

voidbubbleSort(Tarr[],intn){

   boolswapped;

   do{

       swapped=false;

       for(inti=1;i<n;i++){

           if(arr[i-1]>arr[i]){

               swap(arr[i-1],arr[i]);

               swapped=true;

           }

       }

       // 优化, 每一趟Bubble Sort都将最大的元素放在了最后的位置

       // 所以下一次排序, 最后的元素可以不再考虑

       n--;

   }while(swapped);

}

第二版

使用newn进行优化,记录最后交换的位置

template<typenameT>

voidbubbleSort(Tarr[],intn){

   intnewn;//使用newn进行优化

   do{

       newn=0;

       for(inti=1;i<n;i++){

           if(arr[i-1]>arr[i]){

               swap(arr[i-1],arr[i]);

               //记录最后一次交换位置,在此之后的元素在下一轮扫描中不被考虑

               newn=i;

           }

       }

       n=newn;

   }while(n>0);

}

python实现

defbubbleSort(arr):

   n = len(arr)

   foriinrange(n):

       flag = 1

       forjinrange(1, n-i):

           ifarr[j-1] >arr[j]:

               arr[j-1], arr[j] = arr[j], arr[j-1]

               flag = 0

       ifflag == 1:

           break

   returnarr


目录
相关文章
模型中所包含的信息是什么呢?
一、指导设计思路。在项目早期所建立的高层模型用于集中利益相关者的思路和强调一些重要的选择方案。这些模型描述了系统的需求并代表了整个系统设计工作的起点。早期的模型帮助项目发起者在把精力放在系统的细节问题之前研究项目可能的选择方案。
1011 0
|
12天前
|
弹性计算 关系型数据库 微服务
基于 Docker 与 Kubernetes(K3s)的微服务:阿里云生产环境扩容实践
在微服务架构中,如何实现“稳定扩容”与“成本可控”是企业面临的核心挑战。本文结合 Python FastAPI 微服务实战,详解如何基于阿里云基础设施,利用 Docker 封装服务、K3s 实现容器编排,构建生产级微服务架构。内容涵盖容器构建、集群部署、自动扩缩容、可观测性等关键环节,适配阿里云资源特性与服务生态,助力企业打造低成本、高可靠、易扩展的微服务解决方案。
1255 5
|
1天前
|
存储 关系型数据库 分布式数据库
PostgreSQL 18 发布,快来 PolarDB 尝鲜!
PostgreSQL 18 发布,PolarDB for PostgreSQL 全面兼容。新版本支持异步I/O、UUIDv7、虚拟生成列、逻辑复制增强及OAuth认证,显著提升性能与安全。PolarDB-PG 18 支持存算分离架构,融合海量弹性存储与极致计算性能,搭配丰富插件生态,为企业提供高效、稳定、灵活的云数据库解决方案,助力企业数字化转型如虎添翼!
|
11天前
|
机器学习/深度学习 人工智能 前端开发
通义DeepResearch全面开源!同步分享可落地的高阶Agent构建方法论
通义研究团队开源发布通义 DeepResearch —— 首个在性能上可与 OpenAI DeepResearch 相媲美、并在多项权威基准测试中取得领先表现的全开源 Web Agent。
1275 87
|
12天前
|
云栖大会
阿里云云栖大会2025年9月24日开启,免费申请大会门票,速度领取~
2025云栖大会将于9月24-26日举行,官网免费预约畅享票,审核后短信通知,持证件入场
1821 13