Java排序算法中的插入排序算法实现

 更新时间:2023年12月12日 09:13:32   作者:warybee  
这篇文章主要介绍了Java排序算法中的插入排序算法实现,插入排序是将数组中的数据分为两个区间,已排序区间和未排序区间,其中已排序区间初始只有一个元素,就是数组的第一个元素,需要的朋友可以参考下

Java插入排序算法

1、排序原理

插入排序是将数组中的数据分为两个区间,已排序区间和未排序区间,其中已排序区间初始只有一个元素,就是数组的第一个元素。插入算法的核心思想是取未排序区间中的元素,在已排序区间中找到合适的插入位置将其插入,并保证已排序区间数据一直有序。重复这个过程,直到未排序区间中元素为空,算法结束。通过一张动态图,来直观感受一下,要排序的数组为:[4,5,6,1,3,2],正序排序

在这里插入图片描述

1.1、排序过程详解

要排序的数组为:[4,5,6,1,3,2] ,假设 a为已排序区间,b为未排序区间,初始a=[4] ,b=[5 ,6, 1, 3, 2]

第一次遍历未排序区间:

未排序区间中的 5 依次与已排序区间中的数据[4]比较

5和4比较,5大于4,不进行数据移动,结束此次遍历。此时排序区间 a=[4,5] 未排序区间b=[ 6, 1, 3, 2],结果:[4,5,6,1,3,2]

第二次遍历未排序区间:

未排序区间中的 6 依次与已排序区间中的数据[4,5]比较

6和5比较,6大于5,不进行数据移动,结束此次遍历。此时排序区间 a=[4,5,6] ,未排序区间b=[ 1, 3, 2],结果:[4,5,6,1,3,2]

第三次遍历未排序区间:

未排序区间中的 1 依次与已排序区间中的数据[4,5,6]比较

1和6比较,1小于6,进行数据移动,结果:[4,5,1,6,3,2]

1和5比较,1小于5,进行数据移动,结果:[4,1,5,6,3,2]

1和4比较,1小于4,进行数据移动,结果:[1,4,5,6,3,2] ,此时1在已排序区间中找到合适的插入位置,此时排序区间 a=[1,4,5,6] ,未排序区间b=[3, 2]

第四次遍历未排序区间:

未排序区间中的 3 依次与已排序区间中的数据[1,4,5,6]比较

排序后结果:[1,3,4,5,6,2],此时排序区间 a=[1,3,4,5,6] ,未排序区间b=[ 2]

第五次遍历未排序区间:

未排序区间中的 2 依次与已排序区间中的数据[1,3,4,5,6]比较

排序后结果:[1,2,3,4,5,6],此时排序区间 a=[1,2,3,4,5,6] ,未排序区间为空b=[ ],排序结束

2、代码实现

明白了上面的原理,代码实现起来就容易多了

/**     * 插入排序     * @param arr     * @return     */    public static int[] insertionSort(int[] arr) {        for (int i = 1; i < arr.length; i++) {            //待排序元素            int value=arr[i];            //已排序元素下标            int insertIndex=i-1;            //使用待排序元素依次与已排序区的元素相比较            while (insertIndex>=0&&value<arr[insertIndex]){                arr[insertIndex+1]=arr[insertIndex];                insertIndex--;            }            //把当前未排序数据插入到已排序区间            arr[insertIndex+1]=value;        }        return arr;    }

3、算法分析

3.1、时间复杂度

  • 最好情况:T(n)=O(n)
  • 最坏情况:T(n)=O(n^2)
  • 平均情况:T(n)=O(n^2)

3.2、是否稳定

在插入排序中,对于值相同的元素,我们可以选择将后面出现的元素,插入到前面出现元素的后面,这样就可以保持原有的前后顺序不变,所以插入排序是稳定的排序算法。

到此这篇关于Java排序算法中的插入排序算法实现的文章就介绍到这了,更多相关Java插入排序算法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • java -D参数设置系统属性无效问题及解决

    java -D参数设置系统属性无效问题及解决

    这篇文章主要介绍了java -D参数设置系统属性无效问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • Spring 注解编程模型相关知识详解

    Spring 注解编程模型相关知识详解

    这篇文章主要介绍了Spring 注解编程模型相关知识详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-09-09
  • Java运行时环境之ClassLoader类加载机制详解

    Java运行时环境之ClassLoader类加载机制详解

    这篇文章主要给大家介绍了关于Java运行时环境之ClassLoader类加载机制的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-01-01
  • Mybatis实体类和表映射问题(推荐)

    Mybatis实体类和表映射问题(推荐)

    在项目开发中我们经常会遇到表中的字段名和表对应实体类的属性名称不一定都是完全相同的。下面小编给大家介绍下这种情况下如何解决字段名与实体类属性名不相同的冲突问题。下面小编给大家带来了Mybatis实体类和表映射的解决方法,小伙伴们一起学习吧
    2016-09-09
  • 关于SpringBoot中controller参数校验的使用

    关于SpringBoot中controller参数校验的使用

    本文主要介绍了关于SpringBoot中controller参数校验的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • springboot默认日志框架选择源码解析(推荐)

    springboot默认日志框架选择源码解析(推荐)

    这篇文章主要介绍了springboot默认日志框架选择源码解析(推荐),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-03-03
  • Java程序单实例运行的简单实现

    Java程序单实例运行的简单实现

    这篇文章主要介绍了Java程序单实例运行的简单实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08
  • springboot配置Jackson返回统一默认值的实现示例

    springboot配置Jackson返回统一默认值的实现示例

    在项目开发中,我们返回的数据或者对象没有的时候一般直接返回的null,那么如何返回统一默认值,感兴趣的可以了解一下
    2021-07-07
  • spring结合redis如何实现数据的缓存

    spring结合redis如何实现数据的缓存

    这篇文章主要介绍了spring结合redis如何实现数据的缓存,实现的目的目的不是加快查询的速度,而是减少数据库的负担,需要的朋友可以参考下
    2015-12-12
  • 9个java数组常用操作实例

    9个java数组常用操作实例

    在本篇文章里小编给各位整理了关于java数组常用操作的实例以及相关的代码,需要的朋友们跟着学习下。
    2019-07-07

最新评论