美文网首页
冒泡算法java实现

冒泡算法java实现

作者: 牙齿不帅 | 来源:发表于2020-05-12 20:22 被阅读0次
import java.util.Arrays;

public class Bubbling {
    public static void main(String args[]) {

        int array[] = {6, 5, 4, 3, 2, 1, 0};
        sort(array);
        sort2(array);

    }

    /**
     * O((n-1)+(n-2)+(n-3)...1)=O((n-1)*n/2)=O(1/2*n^2-1/2*n)=O(n^2)
     * 1,2,3,4,5,6=(7+7+7)=(n+1)*n/2=1/2n^2+1/2n=21
     * 这是一种冒泡法的实现,不过这种排序是循环的与每一个元素进行比较,无论数据如何分布都会进行比较,用的是内外层循环比较。
     *
     * @param array
     */
    public static void sort(int array[]) {
        int n = 0;
        if (array == null || array.length < 2) {
            return;
        }
        for (int i = 0; i < array.length - 1; i++) {
            int a = array[i];
            n++;
            //循环从下一个元素开始,与之后的每一个元素比较,如果其比我小,我就与其交换
            for (int j = i + 1; j < array.length; j++) {
                int b = array[j];
                if (a > b) {
                    array[i] = b;
                    array[j] = a;
                    a = b;
                }
                n++;
            }
            System.out.println(Arrays.toString(array));

        }
        System.out.println(n);
        System.out.println(Arrays.toString(array));
    }

    /**
     * 与上一个排序不同,所有的元素比较都是在内层做的,每一个都与下一个比较,大于则交换位置,所以末尾的是最大的一个。
     * 这样的好处是:能够判断出元素没有进行过比较交换的操作,顺序就是递增的,不需要进行比较了,从而避免了无效的比较操作。
     * 时间复杂度:
     * 1.最坏情况:与上一种一样。
     * 2.最好情况:O(n-1)=O(n)
     *
     * @param array
     */
    public static void sort2(int array[]) {
        int n = 0;
        if (array == null || array.length < 2) {
            return;
        }
        boolean swap = false;
        for (int i = 0; i < array.length - 1; i++) {//只需要比较n-1次,因为最后一个不需要比较,所以范围-1
            n++;
            //循环从下一个元素开始,与之后的每一个元素比较,如果其比我小,我就与其交换
            for (int j = 0; j < array.length - i - 1; j++) {
                int a = array[j];
                //j+1的位置,所以j判断的范围需要缩小1个
                int b = array[j + 1];
                //内层循环的每一个都与下一个比较
                if (a > b) {
                    array[j + 1] = a;
                    array[j] = b;
                    swap = true;
                }
                n++;
            }
            System.out.println(Arrays.toString(array));
            //如果数据已经是按照从小到大的顺序了,那么就不用再比较了
            if (!swap) {
                break;
            }

        }
        System.out.println(n);
        System.out.println(Arrays.toString(array));
    }

}

相关文章

  • 数据结构&算法(一)

    一、Java实现快速排序算法 二、Java实现折半插入排序算法 三、Java实现冒泡排序算法

  • 冒泡算法java实现

  • java 实现排序算法之「选择排序」

    java 实现排序算法系列 继冒泡排序算法之后,选择排序终于和大家见面了。为什么冒泡排序之后要说选择排序呢,是因为...

  • java实现冒泡排序算法

    java实现冒泡排序算法 介绍 冒泡排序是一种算法,比较相邻元素,如果他们处在错误的位置上,那么交换他们的位置。排...

  • 算法-冒泡排序

    算 法:冒泡排序算法时间复杂度: 冒泡排序算法概述 冒泡排序伪代码 冒泡排序实现 冒泡排序算法概述 冒泡排...

  • 七大排序算法之冒泡排序

    七大排序算法之冒泡排序 @(算法笔记)[排序算法, 冒泡排序, C++实现] 冒泡排序介绍 冒泡排序是七大排序算法...

  • 必须知道的排序算法和对应语言的实现

    必须知道的排序算法—Java实现 1 冒泡排序 冒泡排序是一种简单的排序算法。它重复地走访过要排序的数列,一次比较...

  • java实现冒泡排序算法

    1、原理 比较两个相邻的元素,将值大的元素交换到右端。 2、思想 依此比较相邻两个数,小的数放在前面,大的数放在后...

  • 冒泡排序 选择排序

    冒泡排序 java 实现 C 实现 选择排序 java 实现 C 实现

  • 前端算法学习-第一篇

    冒泡排序算法 冒泡排序算法是最慢的排序算法之一,也是最容易实现的排序算法。之所以叫冒泡排序是因为使用这种算法排序时...

网友评论

      本文标题:冒泡算法java实现

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