冒泡排序java代码

冒泡排序就是依次取出最大数,然后依次交换放到数组最后边。

直观写法:

public long[] sort(long[] a){
        
        int n = a.length - 1;
        // Step:1 选出最大数
        for(int i = 0 ; i < n; i++){
             如果前一个数大于后一个数则交换
            if(a[i] > a[i+1]){
                a[i] = a[i] ^ a[i+1];
                a[i+1] = a[i+1] ^ a[i];
                a[i] = a[i] ^ a[i+1];
            }
        }
        n-- Step:2 选出第二大数
         Step:3
         Step:4
        ;
        System.out.println("n=" + n);
         Step:5
        return a;
    }

加个for循环:

int j = 0 ; j < a.length ; j++){
                 如果前一个数大于后一个数则交换
                ]){
                    a[i] = a[i] ^ a[i+1];
                    a[i+1] = a[i+1] ^ a[i];
                    a[i] = a[i] ^ a[i+1];
                }
            }
            n--;
        }
         a;
    }

相关文章

背景:计算机内部用补码表示二进制数。符号位1表示负数,0表...
大家好,我们现在来讲解关于加密方面的知识,说到加密我认为不...
相信大家在大学的《算法与数据结构》里面都学过快速排序(Qui...
加密在编程中的应用的是非常广泛的,尤其是在各种网络协议之...
前言我的目标是写一个非常详细的关于diff的干货,所以本文有...
对称加密算法 所有的对称加密都有一个共同的特点:加密和...