思想:假设,从小到大排序。只需将大的元素往后迁移,通过交换相邻两元素的位置,使得最大的元素放在最后面,第二大的元素放在倒数第二位。
import java.util.Arrays;
public class BubbleSort {
private static void bubbleSort(int[] arr){
int len=arr.length;
for(int i=0;i<len;i++){
for(int j=0;j<len-i-1;j++){
if(arr[j]>arr[j+1]){
swap(arr,j,j+1);
}
}
}
}
private static void swap(int[] arr,int i,int j){
int temp=arr[i];
arr[i]=arr[j];
arr[j]=temp;
}
public static void main(String[] args) {
int[] arr=new int[]{9,8,7,6,5,4,3,2,1};
bubbleSort(arr);
System.out.println(Arrays.toString(arr));
}
}
算法时间复杂度为:O(n^2)
优化:如果将几个数移到数组后方以后,数组就已经有序了,此时不需要再进行比较,可以退出循环。
public class BubbleSort02 {
private int[] bubbleSort(int[] arr){
boolean flag=true;
while(flag){
for(int i=0;i<arr.length;i++){
flag=false;
for(int j=0;j<arr.length-i;j++){
if(arr[j]>arr[j+1]){
//如果一轮比较下来交换了元素,则没有排好序,还需要进行下一轮交换
flag=true;
swap(arr,j,j+1);
}
}
}
}
return arr;
}
private void swap(int[] arr,int i,int j){
int temp=arr[i];
arr[i]=arr[j];
arr[j]=temp;
}
}