冒泡排序

冒泡排序(Bubble Sort)

  • 概念

   顾名思义,冒泡排序就像水中冒泡一样,较大的数沉下去,较小的数慢慢冒起来;它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成

            

 

  • 步骤

   比较相邻的元素。如果第一个比第二个大,就交换他们两个。

    对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。这步做完后,最后的元素会是最大的数。

    针对所有的元素重复以上的步骤,除了最后一个。

    持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

 

  • Java代码实现
public class BubbleSort {
    public void bubbleSort(Integer arr[]){
        //先判断数组元素是否只有一个以下,若只有一个就不用排序
        if(arr.length<=1) return;
        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;
                }
            }
    }
    public static void main(String[] args) {
        Integer arr[] = {5,7,9,1,2,3};
        System.out.println("排序前的数组:"+Arrays.toString(arr));
        BubbleSort bubbleSort = new BubbleSort();
        bubbleSort.bubbleSort(arr);
        System.out.println("排序后的数组:"+Arrays.toString(arr));
        //最终输出结果:
        //排序前的数组:[5, 7, 9, 1, 2, 3]
        //排序后的数组:[1, 2, 3, 5, 7, 9]

    }
}

 

posted @ 2020-05-26 11:14  发育中的程序猿  阅读(127)  评论(0编辑  收藏  举报