图解Java经典算法冒泡排序的原理与实现
作者:Binaire-沐辰 时间:2023-03-14 21:41:23
冒泡排序
冒泡排序是一种比较简单的排序算法,我们可以重复遍历要排序的序列,每次比较两个元素,如果他们顺序错误就交换位置,重复遍历到没有可以交换的元素,说明排序完成。
算法原理
从第一个元素开始,比较相邻的两个元素,如果第一个大于第二个,则交换它们
对每一对相邻的元素做相同的操作,从第一对到最后一对,最终最后一位元素就是最大值
对每一个元素重复上述步骤,最后一个除外
动图演示
算法练习
题目描述: 给定一个无序数组,利用冒泡排序将数组按升序排列。
示例一:
输入: arrs= [5,0,9,3,-1,12]
输出: arrs= [-1,0,3,5,9,12]
示例二:
输入: arrs= [3,5,9,7,2,1]
输出: arrs= [1,2,3,5,7,9]
解题思路:
通过比较相邻的元素,如果前一个比后一个大,则交换位置。
第一趟:比较第1个和第2个元素,然后是第2个和第3个比较,这样直到倒数第2个和最后1个,将最大的数移动到最后一位。
第二趟:重复上面步骤,将第二大的数交换至倒数第二位。
…
每一趟都会将元素中第 n 大的元素交换到倒数第 n 位。
一共需要n-1趟。
代码实现:
public class BubbleTest {
public static void main(String[] args) {
Integer[] arr = {3,5,9,7,2,1};
Bubble.sort(arr);
System.out.println(Arrays.toString(arr));
}
//数组排序
public static void bubblesort(Comparable[] a){
for (int i = a.length - 1;i > 0;i--){
for (int j = 0;j < i;j++){
if (greater(a[j],a[j + 1])){
swap(a,j,j + 1);
}
}
}
}
//比较 v 是否大于 w
public static boolean greater(Comparable v,Comparable w){
return v.compareTo(w) > 0;
}
//数组元素交换位置
private static void swap(Comparable[] a,int i,int j){
Comparable temp;
temp = a[i];
a[i] = a[j];
a[j] = temp;
}
}
算法分析
时间复杂度
冒泡排序是一种用时间换空间的排序方法,最坏情况是把顺序的排列变成逆序,或者把逆序的数列变成顺序。在这种情况下,每一次比较都需要进行交换运算。
而对于有n个元素的数列它的比较次数为 (n-1) + (n-2) + … + 1 = n * (n - 1) / 2;因此它的时间复杂度为O(n^2)。
空间复杂度
冒泡排序的辅助变量只是一个临时变量,不会随数组规模的增大而增大,所以冒泡排序的空间复杂度为O(1)。
来源:https://binaire.blog.csdn.net/article/details/126298003
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
SpringBoot 添加本地 jar 文件的操作步骤
![](https://img.aspxhome.com/file/2023/8/88178_0s.jpg)
C#文件上传的简单实现
![](https://img.aspxhome.com/file/2023/1/102291_0s.jpg)
Java编程之双重循环打印图形
Java 实战项目之精品养老院管理系统的实现流程
![](https://img.aspxhome.com/file/2023/7/125247_0s.jpg)
c#使用filesystemwatcher实时监控文件目录的添加和删除
java实现简单学生成绩管理系统
![](https://img.aspxhome.com/file/2023/8/98708_0s.jpg)
C++实现哈夫曼树算法
![](https://img.aspxhome.com/file/2023/9/127509_0s.png)
C# LINQ查询表达式及对应LAMBDA表达式的用法
![](https://img.aspxhome.com/file/2023/7/77257_0s.png)
Android7.0中关于ContentProvider组件详解
java字节码框架ASM的深入学习
SpringBoot整合mybatis常见问题(小结)
![](https://img.aspxhome.com/file/2023/6/108366_0s.png)
android中SQLite使用及特点
![](https://img.aspxhome.com/file/2023/5/126675_0s.png)
Spring Boot 实现配置文件加解密原理
![](https://img.aspxhome.com/file/2023/4/59584_0s.jpg)
详解Java实现缓存(LRU,FIFO)
![](https://img.aspxhome.com/file/2023/1/64101_0s.png)
Winform实现将网页生成图片的方法
![](https://img.aspxhome.com/file/2023/8/76388_0s.jpg)
flutter 屏幕尺寸适配和字体大小适配的实现
Java基础知识精通二维数组的应用
Android WebView实现长按保存图片及长按识别二维码功能
![](https://img.aspxhome.com/file/2023/6/139336_0s.gif)
JAVA JDK8 List分组的实现和用法
C#微信开发之获取接口调用凭据
![](https://img.aspxhome.com/file/2023/0/108780_0s.png)