冒泡排序

作者: Airycode | 来源:发表于2018-04-18 10:08 被阅读4次

简化版的桶排序很浪费空间,我们为了解决浪费空间的问题,引入冒泡排序。冒泡排序的基本思想是:每次比较相邻的两个数据,如果顺序错误就把他们交换。
举一个简单的栗子:比如我待排序的数组是arr[12,35,99,18,76],我们的需求是按照从大到小数据排序。
排序的过程:
第一趟冒泡排序结果[35,99,18,76,12].首先我们通过冒泡排序的想象模拟排序的过程:
12和35交换交换后的结果是:[35,12,99,18,76].
12和99交换交换后的结果是[35,99,12,18,76].
12和18交换交换后的结果是[35,99,18,12,76].
12和76比较交换交换后的结果:[35,99,18,76,12].
OK,12这个数据已经排序完成,重复上面的操作直到数据排序完成。
冒泡排序的原理是:每一趟只能确定一个数归位。总结如下:如果有n个数进行排序,只需要将n-1个数归位,也就是说要进行n-1趟操作,而且每一趟都需要从第一位开始进行相邻两个数比较,将较小的数字放在后面,比较完毕后挪一位继续比较下面两个相邻数的大小,重复此步骤知道最后一个尚未归位的数。已经归位的数字则无需进行比较。


public class MaoPao {

    public static void main(String[] args) {
        int [] arr={12,35,99,18,76};
        maoPao(arr);
        printArray(arr);
    }

    private static void maoPao(int[] arr) {
        
        for (int i=arr.length-1;i>0;i--) {
            for (int j=0;j<i;j++) {
                if (arr[j]<=arr[j+1]) {
                    swap(arr,j,j+1);
                }
            }
        }
        
        
    }
    public static void swap(int[] arr, int i, int j) {
        arr[i] = arr[i] ^ arr[j];
        arr[j] = arr[i] ^ arr[j];
        arr[i] = arr[i] ^ arr[j];
    }
    
    public static void printArray(int[] arr) {
        if (arr == null) {
            return;
        }
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }
        System.out.println();
    }
    
}

相关文章

网友评论

    本文标题:冒泡排序

    本文链接:https://www.haomeiwen.com/subject/ykamkftx.html