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
目录
相关文章
|
2月前
|
存储 Java API
Java交换map的key和value值
通过本文介绍的几种方法,可以在Java中实现Map键值对的交换。每种方法都有其优缺点,具体选择哪种方法应根据实际需求和场景决定。对于简单的键值对交换,可以使用简单遍历法或Java 8的Stream API;对于需要处理值不唯一的情况,可以使用集合存储或Guava的Multimap。希望本文对您理解和实现Java中的Map键值对交换有所帮助。
48 1
|
3月前
|
机器学习/深度学习 算法 搜索推荐
让星星⭐月亮告诉你,Java冒泡排序及其时间复杂度计算
冒泡排序是一种简单的排序算法,通过多次遍历数组,每次比较相邻元素并交换位置,将较小的元素逐步移至数组前端。第一轮结束后,最小值会位于首位;第二轮则将次小值置于第二位,依此类推。经过 (n-1) 轮遍历后,数组完成排序。冒泡排序的时间复杂度为 O(n²),在最优情况下(已排序数组)时间复杂度为 O(n)。示例代码展示了如何实现冒泡排序。
80 1
|
3月前
|
算法 Java
java冒泡排序与二分查找(详解)
java冒泡排序与二分查找(详解)
50 4
|
3月前
|
存储 搜索推荐 算法
【用Java学习数据结构系列】七大排序要悄咪咪的学(直接插入,希尔,归并,选择,堆排,冒泡,快排)以及计数排序(非比较排序)
【用Java学习数据结构系列】七大排序要悄咪咪的学(直接插入,希尔,归并,选择,堆排,冒泡,快排)以及计数排序(非比较排序)
35 1
|
3月前
|
人工智能 Java
java之冒泡排序8个数
java之冒泡排序8个数
23 0
|
5月前
|
存储 Java
Java中ArrayList 元素的排序
本文提供了Java中根据`ArrayList`元素的某个属性进行排序的示例代码,包括实现`Comparable`接口和重载`compareTo`方法,然后使用`Collections.sort`方法进行排序。
|
5月前
|
存储 Java
|
5月前
|
存储 Java
|
5月前
|
存储 搜索推荐 Java
|
1天前
|
监控 Java
java异步判断线程池所有任务是否执行完
通过上述步骤,您可以在Java中实现异步判断线程池所有任务是否执行完毕。这种方法使用了 `CompletionService`来监控任务的完成情况,并通过一个独立线程异步检查所有任务的执行状态。这种设计不仅简洁高效,还能确保在大量任务处理时程序的稳定性和可维护性。希望本文能为您的开发工作提供实用的指导和帮助。
31 17