数据结构与算法(七)排序--冒泡排序

冒泡排序:

冒泡排序(Bubble Sorting)的基本思想是:通过对待
排序序列从前向后(从下标较小的元素开始),依次比较
相邻元素的值,若发现逆序则交换,使值较大
的元素逐渐从前移向后部,就象水底下的气泡一样逐渐
向上冒。

代码实现


    /**
     * 冒泡排序
     * @param arr
     */
    public static  void bubbleSort(int [] arr){
        int temp=0;
        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]){
                    temp=arr[j];
                    arr[j]=arr[j+1];
                    arr[j+1]=temp;
                }
            }
        }
    }

如果一趟比较下来,没有元素交换,就说明已经是有序的了,不需要之后的比较了。因此可以优化冒泡排序。

  /**
     * 冒泡排序优化
     * @param arr
     */
    public static  void bubbleSort2(int [] arr){
        int temp=0;
        boolean flag=false;
        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]){
                    temp=arr[j];
                    arr[j]=arr[j+1];
                    arr[j+1]=temp;
                    flag=true;
                }
            }
            if (flag){
                flag=false;
            }else {
                break;
            }
        }
    }
更新时间:2020-07-20 20:28:31

本文由 过去的,未来的 创作,如果您觉得本文不错,请随意赞赏
采用 知识共享署名4.0 国际许可协议进行许可
本站文章除注明转载/出处外,均为本站原创或翻译,转载前请务必署名
原文链接:https://www.fengpt.cn/archives/数据结构与算法排序--冒泡排序
最后更新:2020-07-20 20:28:31

评论

Your browser is out of date!

Update your browser to view this website correctly. Update my browser now

×