网站首页 > 精选教程 正文
程序代码园发文地址:Java算法总结之冒泡排序(详解)-程序代码园
冒泡排序(默认升序)
算法原理:
1、比较相邻的元素。如果第一个比第二个大,就交换他们两个。
2、对每一对相邻元素做同样的工作,从开始第一对到结尾的最后一对。在这一点,每一轮最后的元素应该会是最大的数。
代码示例:
/**
* 基本原理
* @param 整型数组arr
* @return 整型数组arr
*/
public int[] BubbleSortBasic(int[] arr){
for(int i = 0;i < arr.length;i++){//排序所需的趟数
for(int j = 0;j < arr.length - 1 - i;j++){//每趟比较次数
if(arr[j] > arr[j+1]){
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
System.out.println("第"+(i+1)+"次排序:"+Arrays.toString(arr));
}
return arr;
}
运行结果:
从运行结果可以看出,14个数字,需要进行14次排序操作才可以得到最后的结果,但是在第8次已经得到最后的结果,后面运行的排序都是可以省略的。
优化一下代码:
/**
* 优化
* @param 整型数组arr
* @return 整型数组arr
* boolean flag 优化,检查每一趟之后是否有序
*/
public int[] BubbleSortOptimize(int[] arr){
for(int i = 0;i < arr.length;i++){//排序所需的趟数
boolean flag = false;
for(int j = 0;j < arr.length - 1 - i;j++){//每趟比较次数
if(arr[j] > arr[j+1]){
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
flag = true;
}
}
System.out.println("第"+(i+1)+"次排序:"+Arrays.toString(arr));
if(flag == false){//如果已经有序,则返回排序后的数组
break;
}
}
return arr;
}
运行结果:
从运行结果可以看出,14个数字,需要进行9次排序操作才可以得到最后的结果,但是在第8次已经得到最后的结果,第9次排序是因为需要检验前面的排序也没有得到正确的排序结果。
优化后的排序算法,减少遍历次数,更加高效,建议使用。
程序代码园发文地址:Java算法总结之冒泡排序(详解)-程序代码园
- 上一篇: Java排序之冒泡排序
- 下一篇: java实现冒泡排序
猜你喜欢
- 2024-12-04 程序入门:冒泡排序(C++)
- 2024-12-04 算法学习-JavaScript冒泡排序与选择排序
- 2024-12-04 西门子SCL编程实例——冒泡排序算法(更新版)
- 2024-12-04 python冒泡排序
- 2024-12-04 C语言 冒泡排序
- 2024-12-04 Python中的关键算法之”冒泡排序“
- 2024-12-04 西门子SCL语言编程实例——冒泡排序
- 2024-12-04 宇哥编程算法练习:冒泡排序的原理(基于Access数据库VBA)
- 2024-12-04 看动画学算法之:排序-冒泡排序
- 2024-12-04 西门子SCL编程实例—冒泡排序算法的实现
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- nginx反向代理 (57)
- nginx日志 (56)
- nginx限制ip访问 (62)
- mac安装nginx (55)
- java和mysql (59)
- java中final (62)
- win10安装java (72)
- java启动参数 (64)
- java链表反转 (64)
- 字符串反转java (72)
- java逻辑运算符 (59)
- java 请求url (65)
- java信号量 (57)
- java定义枚举 (59)
- java字符串压缩 (56)
- java中的反射 (59)
- java 三维数组 (55)
- java插入排序 (68)
- java线程的状态 (62)
- java异步调用 (55)
- java中的异常处理 (62)
- java锁机制 (54)
- java静态内部类 (55)
- java怎么添加图片 (60)
- java 权限框架 (55)
本文暂时没有评论,来添加一个吧(●'◡'●)