Java冒泡排序代码怎么写

Java冒泡排序代码怎么写

本篇内容介绍了“Java冒泡排序代码怎么写”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

冒泡排序是计算机的一种排序方法,它的时间复杂度为O(n^2),虽然不及堆排序、快速排序的O(nlogn,底数为2),但是有两个优点:

Java冒泡排序代码怎么写

1.“编程复杂度”很低,很容易写出代码;

2.具有稳定性,这里的稳定性是指原序列中相同元素的相对顺序仍然保持到排序后的序列,而堆排序、快速排序均不具有稳定性。

不过,一路、二路归并排序、不平衡二叉树排序的速度均比冒泡排序快,且具有稳定性,但速度不及堆排序、快速排序。冒泡排序是经过n-1趟子排序完成的,第i趟子排序从第1个数至第n-i个数,若第i个数比后一个数大(则升序,小则降序)则交换两数。

冒泡排序算法稳定,O(1)的额外的空间,比较和交换的时间复杂度都是O(n^2),自适应,对于已基本排序的算法,时间复杂度为O(n)。冒泡算法的许多性质和插入算法相似,但对于系统开销高一点点。

排序过程

设想被排序的数组R[1..N]垂直竖立,将每个数据元素看作有重量的气泡,根据轻气泡不能在重气泡之下的原则,从下往上扫描数组R,凡扫描到违反本原则的轻气泡,就使其向上"漂浮",如此反复进行,直至***任何两个气泡都是轻者在上,重者在下为止。

代码实现:

//冒泡排序publicclassBubbleSort{publicstaticvoidsort(Comparable[]data){//数组长度intlen=data.length;for(inti=0;i<len-1;i++){//临时变量Comparabletemp=null;//交换标志,false表示未交换booleanisExchanged=false;for(intj=len-1;j>i;j--){//如果data[j]小于data[j-1],交换if(data[j].compareTo(data[j-1])<0){temp=data[j];data[j]=data[j-1];data[j-1]=temp;//发生了交换,故将交换标志置为真isExchanged=true;}//endif}//endfor//本趟排序未发生交换,提前终止算法,提高效率if(!isExchanged){return;}//endif}//endfor}//endsortpublicstaticvoidmain(String[]args){//在JDK1.5版本以上,基本数据类型可以自动装箱//int,double等基本类型的包装类已实现了Comparable接口Comparable[]c={4,9,23,1,45,27,5,2};sort(c);for(Comparabledata:c){System.out.println(data);}}}

使用冒泡排序法对n个数据进行排序,共需要进行n-1次的比较。如果本来就是有顺序的数据,也需要进行n-1次比较。冒泡排序法的算法很简单,效率也较差。

“Java冒泡排序代码怎么写”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

发布于 2022-01-06 23:29:04
收藏
分享
海报
0 条评论
37
上一篇:Java的ClassLoader有什么用 下一篇:UML静态结构图与动态行为图的作用是什么
目录

    0 条评论

    本站已关闭游客评论,请登录或者注册后再评论吧~

    忘记密码?

    图形验证码