冒泡排序原理:
冒泡排序思路就是交换排序,通过相邻数据的交换来达到排序的目的
冒泡排序思路:
1、对数组中的各数据,一次比较相邻的两个元素的大小。
2、如果前面的数据大于后面的数据,就交换两个数据,经过第一轮的多次比较排序后,便可以将最小的数据排好。
3、再用同样的的方法把剩下的数据逐个进行排序,最后便可以按照从小到大顺序排好各组数据。
举例说明:
初始数据:118、101、105、127、112
第一趟排序:
101、118、105、112、127
第二趟排序:
101、105、118、112、127
第三趟排序:
101、105、112、118、127
第四次排序:
101、105、112、118、127
冒泡算法在对n个数据进行排序时,无论原数据有无顺序,都需要进行n-1步的中间排序,这种排序方法直观简单,但是缺点是执行步骤稍长,效率不高。
由上面的可以总结:N个数字要排序完成,总共进行N-1趟排序,每趟排序次数为(N-i)次,所以可以用双重循环语句,外层控制循环多少趟,内层控制循环每趟的次数:
for(int i=1;i<arr.length;i++){
for(int j=1;j<arr.length-i;j++){
//交换位置
}
}
冒泡排序的优点:每进行一趟排序,就会少比较一次,因为每进行一趟排序都会找出一个较小值
用时间复杂度来说:
1.如果我们的数据正序,只需要走一趟即可完成排序。所需的比较次数C和记录移动次数M均达到最小值,即:Cmin=n-1;Mmin=0;所以,冒泡排序最好的时间复杂度为O(n)。
2.如果很不幸我们的数据是反序的,则需要进行n-1趟排序。每趟排序要进行n-i次比较(1≤i≤n-1),且每次比较都必须移动记录三次来达到交换记录位置。在这种情况下,比较和移动次数均达到最大值:冒泡排序的最坏时间复杂度为:O(n2) 。
综上所述:冒泡排序总的平均时间复杂度为:O(n2) 。
/*
* 冒泡排序
*/
public class BubbleSort {
public static void main(String[] args) {
int[] arr={6,3,8,2,9,1};
System.out.println("排序前数组为:");
for(int num:arr){
System.out.print(num+" ");
}
for(int i=0;i<arr.length-1;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();
System.out.println("排序后的数组为:");
for(int num:arr){
System.out.print(num+" ");
}
}
}