vlambda博客
学习文章列表

算法 | 作为开发竟然不懂算法 - 冒泡排序

关注 程序员漫话编程▲ 看漫画,学编程。

编者荐语:

大家好,我是你们的朋友 朋哥.

说起算法其实大家都知道重要,但是真正理解算法需要在实际开发中使用。

最近开始做算法的有关东西,发现一些不太重视的算法,其实是所有算法逻辑的基础。

很多复杂和庞大的逻辑都是这些小小的算法堆积起来的。

比如我最近就遇到很多使用冒泡排序,今天分享给大家。


有问题请留言。

简介

基本思想:比较前后相邻的两个数据,如果前面数据大于后面的数据,就将这二个数据交换。这样对数组的第 0 个数据到 N-1 个数据进行一次遍历后,最大的一个数据就“沉”到数组第 N-1 个位置。N=N-1,如果 N 不为 0 就重复前面二步,否则排序完成。

场景:数据量不大,对稳定性有要求,且数据基本有序的情况。

步骤

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

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

3、针对所有的元素重复以上的步骤,除了最后已经选出的元素(有序)。

4、持续每次对越来越少的元素(无序元素)重复上面的步骤,直到没有任何一对数字需要比较,则序列最终有序。

复杂度

若文件的初始状态是正序的,一趟扫描即可完成排序。所需的关键字比较次数 和记录移动次数 均达到最小值:所以,冒泡排序最好的时间复杂度为

O(n)


若初始文件是反序的,需要进行n-1趟排序。每趟排序要进行n-i次关键字的比较(1≤i≤n-1),且每次比较都必须移动记录三次来达到交换记录位置。在这种情况下,比较和移动次数均达到最大值:

冒泡排序的最坏时间复杂度为

O(n^2)



综上,因此冒泡排序总的平均时间复杂度为

 O(n^2)


空间复杂度为

 O(1)

核心代码示例:

 
   
   
 
public static void ArraySortTest() { int[] ages= {20,22,30,15,50,12,16,45}; System.out.println(Arrays.toString(ages)); //控制比较轮数 for(int i=1;i<ages.length;i++) { //每轮比较多少 for(int j=0;j<ages.length-i;j++) { if(ages[j]>ages[j+1]) { int tmp=0; tmp=ages[j]; ages[j]=ages[j+1]; ages[j+1]=tmp;  } } } System.out.println(Arrays.toString(ages));}


强烈推荐一个讲解鸿蒙app开发的公号。回复 “鸿蒙” 获取一千鸿蒙开源组件

码工成长记
一个有10年撸码经验,只关心技术的码工。
2篇原创内容
Official Account



推荐阅读






另附资源下载:关注 “程序员漫话编程
1,后台回复:学习资料”,可获取一份3TJava学习视频资料。
2,后台回复:“小抄”,可获取 最新 字节跳动算法资料。

3,后台回复:“面试1000”,可获取 1000多道面试题。

4,后台回复:“面试”,可获取 总结的 30本Java各个类型面试电纸书。

5,右下角点击 联系我 ->「加群」拉你进讨论群一起学习。