网站首页 > java教程 正文
中心思想
通过无序区中的相邻的记录的比较和位置的交换,使记录较小的的数有如气泡一样逐渐往上“漂浮”直至“浮出水面”。
代码实现
public int[] sort(int[] sourceArray) {
// 1.遍历多少次(i)[1,sourceArray.length)
for (int i = 1; i < sourceArray.length; i++) {
// 2.每次遍历多少个[0,sourceArray.length - i)
for (int j = 0; j < sourceArray.length - i; j++) {
// 3.判断是否需要交换位置
if (sourceArray[j] > sourceArray[j + 1]) {
int temp = sourceArray[j];
sourceArray[j] = sourceArray[j + 1];
sourceArray[j + 1] = temp;
}
}
}
return sourceArray;
}
时间复杂度
- 最好情况:正序有序,则只需要比较 n 次。故 为 O(n)
- 最坏情况:逆序有序,则需要比较(n-1)+(n-2)+ ....+ 1次。故为O(N*N)
稳定性
排序过程中只交换相邻的两个元素的位置。因此,当两个数相等时,是没必要交换两个数的位置。他们的相对位置并没有改变。冒泡排序算法是稳定的!
猜你喜欢
- 2024-10-31 「Java基础」你必须知道的Java排序算法
- 2024-10-31 Java排序算法实现方式(算法思路 过程动图)
- 2024-10-31 一文读懂Java排序算法(所有的排序算法比较)
- 2024-10-31 java数据结构与算法之快速排序(用java实现快速排序算法)
- 2024-10-31 开发人员是如何使用Java进行排序?
- 2024-10-31 算法:什么是外部排序(外部排序有哪几种)
- 2024-10-31 Java 常见的排序算法,一次跟你说明白 ~ 直接插入排序
- 2024-10-31 Java排序算法-Java入门|Java基础课程
- 2024-10-31 必看java八大排序算法(java十大排序算法)
- 2024-10-31 冒泡排序、插入排序、选择排序、希尔排序
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)