java进阶- 经典排序(插入排序、冒泡排序、快排(分划交换排序)、直接选择排序、堆排序、合并排序)

简介: 版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/weixin_40254498/article/details/79205834 业余时间学习java,回顾回顾经典算法。
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/weixin_40254498/article/details/79205834

业余时间学习java,回顾回顾经典算法。


插入排序

插入排序的基本思想是:每步将一个待排序的记录,按其关键码值的大小插入前面已经排序的文件中适当位置上,直到全部插入完为止。 —— [ 百度百科 ]

代码

 /**
  * 插入排序
  */
 public void insertSort(int[] array) {
        System.out.println("-----Start 插入排序-----");
        System.out.println(Arrays.toString(array));
        for (int i = 0; i < array.length; i++) {
            int j = i - 1;
            int temp = array[i];
            while (j > -1 && temp < array[j]) {
                array[j + 1] = array[j];
                j--;
            }
            if (temp == array[i]) {
                continue;
            }
            array[j + 1] = temp;
        }
        System.out.println(Arrays.toString(array));
        System.out.println("-----End 插入排序-----");
    }

运行结果

        -----Start 插入排序-----
        [14, 21, 12, 5, 7]
        [5, 7, 12, 14, 21]
        -----End 插入排序-----

冒泡排序

冒泡排序算法的运作如下:(从后往前)
比较相邻的元素。如果第一个比第二个大,就交换他们两个。
对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。
针对所有的元素重复以上的步骤,除了最后一个。
持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。 —— [ 百度百科 ]

代码

  /**
     * 冒泡排序(Bubble Sort)
     */
    public void bubbleSort(int[] array) {

        System.out.println("-----Start 冒泡排序-----");
        System.out.println(Arrays.toString(array));

        int temp = 0;
        for (int i = array.length - 1; i > 0; --i) {
            for (int j = 0; j < i; ++j) {
                if (array[j + 1] < array[j]) {
                    temp = array[j];
                    array[j] = array[j + 1];
                    array[j + 1] = temp;
                }
            }
        }

        System.out.println(Arrays.toString(array));
        System.out.println("-----End 冒泡排序-----");
    }

运行结果

        -----Start 冒泡排序-----
        [5, 7, 12, 14, 21]
        [5, 7, 12, 14, 21]
        -----End 冒泡排序-----

快速排序

快速排序由C. A. R. Hoare在1962年提出。它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。 —— [ 百度百科 ]

代码

    private int count = 0;
    /**
     * 快速排序(Bubble Sort)
     * @param array
     * @param l
     * @param r
     */
    public void quickSort(int[] array, int l, int r) {
        if (l < r)
        {
            int i = l, j = r, x = array[l];
            while (i < j)
            {
                // 从右向左找第一个小于x的数
                while(i < j && array[j] >= x)
                    j--;
                if(i < j)
                    array[i++] = array[j];

                // 从左向右找第一个大于等于x的数
                while(i < j && array[i] < x)
                    i++;
                if(i < j)
                    array[j--] = array[i];
            }
            array[i] = x;
            count ++;
            System.out.println("-----第"+count+"次快速排序-----");
            System.out.println(Arrays.toString(array));
            // 递归调用
            quickSort(array, l, i - 1);
            quickSort(array, i + 1, r);
        }
    }

运行结果

        int[] outOrder = {14, 21, 12, 5, 7,9,55,77,33,12,65,6};

        运行结果:
        -----第1次快速排序-----
        [6, 12, 12, 5, 7, 9, 14, 77, 33, 55, 65, 21]
        -----第2次快速排序-----
        [5, 6, 12, 12, 7, 9, 14, 77, 33, 55, 65, 21]
        -----第3次快速排序-----
        [5, 6, 9, 7, 12, 12, 14, 77, 33, 55, 65, 21]
        -----第4次快速排序-----
        [5, 6, 7, 9, 12, 12, 14, 77, 33, 55, 65, 21]
        -----第5次快速排序-----
        [5, 6, 7, 9, 12, 12, 14, 21, 33, 55, 65, 77]
        -----第6次快速排序-----
        [5, 6, 7, 9, 12, 12, 14, 21, 33, 55, 65, 77]
        -----第7次快速排序-----
        [5, 6, 7, 9, 12, 12, 14, 21, 33, 55, 65, 77]
        -----第8次快速排序-----
        [5, 6, 7, 9, 12, 12, 14, 21, 33, 55, 65, 77]

        Process finished with exit code 0
目录
相关文章
|
1月前
|
Java C语言
用Java(C语言也可以看)实现冒泡排序和折半查找(详细过程图)+逆序数组
用Java(C语言也可以看)实现冒泡排序和折半查找(详细过程图)+逆序数组
28 0
|
10天前
|
缓存 安全 Java
Java并发编程进阶:深入理解Java内存模型
【4月更文挑战第6天】Java内存模型(JMM)是多线程编程的关键,定义了线程间共享变量读写的规则,确保数据一致性和可见性。主要包括原子性、可见性和有序性三大特性。Happens-Before原则规定操作顺序,内存屏障和锁则保障这些原则的实施。理解JMM和相关机制对于编写线程安全、高性能的Java并发程序至关重要。
|
19天前
|
SQL 前端开发 Java
Java后端进阶之路: JavaWeb(四)
Java后端进阶之路: JavaWeb
32 1
|
XML SQL Java
Java后端进阶之路: JavaWeb(三)
Java后端进阶之路: JavaWeb
30 1
|
1月前
|
Java 编译器
[java进阶]——泛型类、泛型方法、泛型接口、泛型的通配符
[java进阶]——泛型类、泛型方法、泛型接口、泛型的通配符
|
1月前
|
Java
【java进阶】Java中线程的实现方式
【java进阶】Java中线程的实现方式
|
1月前
|
Java 索引
【java进阶】集合的三种遍历(迭代器、增强for、Lambda)
【java进阶】集合的三种遍历(迭代器、增强for、Lambda)
【java进阶】集合的三种遍历(迭代器、增强for、Lambda)
|
1月前
|
Java
[java进阶]——stream流你还不会用吗?超详细使用介绍
[java进阶]——stream流你还不会用吗?超详细使用介绍
|
1月前
|
Java
[java进阶]——方法引用改写Lambda表达式
[java进阶]——方法引用改写Lambda表达式
|
1月前
|
算法 搜索推荐 Java
数据结构与算法(Java篇)笔记--插入排序
数据结构与算法(Java篇)笔记--插入排序