11.冒泡排序

 小结:

(1)相邻的元素逆序就交换,一个进行了数组大小-1趟循环

(2)每一趟排序的次数在逐渐的减少

(3)需要优化的地方:如果在某趟排序中没有发生一次交换,可以提前结束排序

import java.util.Arrays;

/**
 * 冒泡排序
 */
public class BubbleSort {
    public static int[] bubbleSort(int[] arr){
        int length = arr.length;
        int temp = 0;
        for (int i = 1; i < length; i++) {
            boolean flag = true;
            for (int j = 0; j < length - i; j++) {
                if (arr[j]>arr[j+1]){
                    flag = false;
                    temp = arr[j];
                    arr[j] = arr[j+1];
                    arr[j+1] = temp;
                }
            }
            if (flag)break;
            System.out.printf("第%d趟的结果是:%s\n",i, Arrays.toString(arr));
        }
        System.out.println("从小到大排序结果为:"+Arrays.toString(arr));
        return arr;
    }
    public static void main(String[] args){
        bubbleSort(new int[]{3, 9, -1, 10, -2});
        bubbleSort(new int[]{3, 9, -2, 10, -1});
        //第1趟的结果是:[3, -1, 9, -2, 10]
        //第2趟的结果是:[-1, 3, -2, 9, 10]
        //第3趟的结果是:[-1, -2, 3, 9, 10]
        //第4趟的结果是:[-2, -1, 3, 9, 10]
        //从小到大排序结果为:[-2, -1, 3, 9, 10]
        //第1趟的结果是:[3, -2, 9, -1, 10]
        //第2趟的结果是:[-2, 3, -1, 9, 10]
        //第3趟的结果是:[-2, -1, 3, 9, 10]
        //从小到大排序结果为:[-2, -1, 3, 9, 10]
    }
}

 

posted @ 2019-10-12 09:51  fly_bk  阅读(194)  评论(0编辑  收藏  举报