Java排序算法——插入排序(Insertion Sort)

article/2025/10/24 6:43:07

之前总结了交换排序的冒泡排序与选择排序的简单选择排序,这次我们来看看插入排序的简单插入排序~

往期传送门:

冒泡排序:

Java排序算法——冒泡排序(Bubble Sort)https://blog.csdn.net/babbfqb93/article/details/123005968简单选择排序:

Java排序算法——选择排序(Selection Sort)https://blog.csdn.net/babbfqb93/article/details/123040023插入排序(Insertion Sort)一般也被称为直接插入排序或者简单插入排序,之所以这样,是因为我们一般把排序算法分为比较类排序与非比较类排序,而比较类排序又可以分为交换排序、插入排序、选择排序与并归排序。整体如下图:

 我们已经讲过了冒泡排序与选择排序(简单选择排序),可以明确感觉的出来,冒泡排序——交换排序,可以看出来是每个比较,之后进行交换。简单选择排序,我们先“选择”需要交换的元素,然后交换,再进行交换这种方式进行排序。现在我们要总结的简单插入排序,则和之前又有所不同。

插入排序,故名思意,是一种“插入”的排序。我们视同原始数据为“无序数组”,将“无序数组”的元素,逐个将元素。插入到“有序数组”中,这一句话总结,可能不太能好理解,所以我们先看一下整体的实现。先把整体的图给大家看一下效果:(最后一栏出现“插入”字符串,说明进行了插入操作)。

我们先看一下第一行的数据,用它作为例子

第一步(分析):

        原始数组,我们默认数组的第一个元素视同一个长度为1的“有序数组”,毕竟他就一个元素,怎么看都是有序的。接下来我们把剩余的数组视同为无序的。

第二步(获取需要比较的元素):

        “红色标记”为我们要比较的元素,我们获取第一个“无序数组”的元素“20”,它是我们本次循环需要被比较的数字。

第三步(获取被比较的元素):

        “黄色标记”为我们被比较的元素,它的取数逻辑是从“有序数组”的最后一个元素开始,如本次比较,“40”就是我们被比较的数字。

第四步(比较):

        如果“红色”比“黄色”大,则记录下当前“黄色”的下标位置,如果结果是小,则继续和“黄色“的上一位比较,直到找到比“红色”小的“黄色”来记录下标或者遍历完整个“有序数组”。

第五步(插入):

        将“红色”插入到记录下的坐标位置,如果没有记录的位置,则视同位置为数组的起点“0”下标。

以上5步可以理解为插入排序的一个内层循环,我们可以用代码将其实现,实现代码如下:

生成随机数方法和之前的方法都是一致的:

//初始换一个长度为参数的随机数组,数组元素为0(含)到50(不含)的随机数
public static int[] initArray(int length){Random r = new Random();//申明并实例化一个Random对象int[] iArray = new int[length];//申明并实例化一个int数组用于测试排序for (int i = 0; i < iArray.length; i++) {//通过Random随机生成一个0(含)到50(不含)的数并插入对应位置iArray[i] = r.nextInt(50);}return iArray;
}

插入方法,插入方法和之前的交换方法不相同,我们的插入不是简单的交换,而是将之前的数字向后移动一位,直到到需要插入的位置,将数值插入进去:

//将下标为i的元素插入到下标为j的元素
public static void swap(int[] iArray,int i,int j){//先将j下标位置存储int temp = iArray[i];//当i>j的时候需要循环,直到j与i坐标相当,每次将j之前一个数向后移动一位,j--for(;i>j;i--){iArray[i]=iArray[i-1];}//最后将i下标设置成被插入数的值iArray[j]=temp;
}

简单插入排序第一层循环逻辑:

public static void insertionSort(int[] iArrays){//默认和0进行交换int index = 0;//被比较的数(“红色”)int temp = iArrays[0 + 1];//遍历之前的“有序数组”,从总循环次数+1开始遍历for (int j = 0+1; j >0; j--) {//如果需比较的数字大于之前的某一个元素,记录元素的下标用于插入if(temp >iArrays[j-1]){index = j;}}//插入交换swap(iArrays,0+1,index);}

这就是第一次的循环,接下来我们需要的就是让所有的数都会被遍历到,并且按照之前的5步走,那么就是将循环次数再次嵌套一层循环,循环的起点是从第0个下标位置开始,终点为数组的最后一个数字之前一位(内层循环会将该次数+1(int j = i+1)所以条件的终点应该是数组长度-1),加上之后讲之前的0改成外层循环变量i就实现了。

public static void insertionSort(int[] iArrays){//循环整体数据for(int i =0;i<iArrays.length-1;i++) {//默认和0进行交换int index = 0;//被比较的数(“红色”)int temp = iArrays[i + 1];//遍历之前的“有序数组”,从总循环次数+1开始遍历for (int j = i + 1; j > 0; j--) {//如果需比较的数字大于之前的某一个元素,记录元素的下标用于插入if ( temp > iArrays[j - 1]) {index = j;//因为之前为有序的所以记录坐标就可以break了break;}}//插入交换swap(iArrays, i + 1, index);}
}

我们写个测试入口测试一下:

public static void main(String[] args) {//初始化数组int[] iArray = initArray(7);//输出排序前结果System.out.println("------排序之前------");System.out.println(Arrays.toString(iArray));System.out.println("-------------------");//排序...System.out.println("------正在排序------");insertionSort(iArray);System.out.println("-------------------");//输出排序后结果System.out.println("------排序之后------");System.out.println(Arrays.toString(iArray));System.out.println("-------------------");
}

实现结果:

 

不过代码还是比较复杂的,我这里是为了更加直接的展示出“插入”与“比较”的不同,其实有更加优化的方法,代码优化的博客也写好了,可以参考一下链接

开个门:

Java排序算法——插入排序(Insertion Sort)代码优化icon-default.png?t=M1H3https://blog.csdn.net/babbfqb93/article/details/123062970

 引用一下个人查询到的相关gif,帮助大家总结一下(我实在找不到gif的作者,这个图用于学习真的很棒!感谢gif图作者)

 

 好,我说完了。


http://chatgpt.dhexx.cn/article/qrHBINon.shtml

相关文章

Java排序算法——冒泡排序(Bubble Sort)

冒泡排序是所有排序算法中最简单的一个排序&#xff0c;也是我个人学习的第一个排序方法&#xff0c;在这里重新进行一个总结。 冒泡排序&#xff08;Bubble Sort&#xff09;就如同其名称一样&#xff0c;水中的气泡由于压强的原因所以从下到上其大小也是从小到大&#xff0c…

Java排序算法——插入排序

Java排序算法——插入排序&#xff08;Insertion Sort&#xff09; 传送门 冒泡排序选择排序 简述 插入排序&#xff08;Insertion Sort&#xff09;是一种简单直观的排序算法。它的工作原理是通过构建有序序列&#xff0c;对于未排序数据&#xff0c;在已排序序列中从后向前…

Java实现排序算法

一、常见排序算法&#xff1a; 1、插入类排序&#xff1a; (1)直接插入排序 (2)希尔排序 2、选择类排序 (1)简单选择排序 (2)堆排序 3、交换类排序 (1)冒泡排序 (2)快速排序 4、归并排序 5、基数排序 二、内部排序&#xff1a;只考虑数据量较小仅需要使用内存的排序算法 三、…

Java排序算法——选择排序

Java排序算法——选择排序&#xff08;Selection sort&#xff09; 传送门 冒泡排序插入排序 简述 选择排序&#xff08;Selection sort&#xff09;是一种简单直观的排序算法。它的工作原理如下。首先在未排序序列中找到最小&#xff08;大&#xff09;元素&#xff0c;存放…

JAVA排序:快速排序算法

Java实现快速排序算法 快速排序算法体现了—分治思想&#xff1a;将大问题划分为多个相同独立的小问题&#xff0c;每个小问题的解决合在一起解决了大问题 实现快速排序的思想&#xff1a; {2,4,1,0,3,5}是目标数组 {0,1,2,3,4,5}是结果数组 选取中心轴pivot(中心轴的值用于比较…

Java排序算法——选择排序(Selection Sort)

上次总结了一下冒泡排序&#xff0c;这次来看看同样非常简单的选择排序 上期冒泡排序传送门&#xff1a; Java排序算法——冒泡排序&#xff08;Bubble Sort&#xff09;https://blog.csdn.net/babbfqb93/article/details/123005968?spm1001.2014.3001.5501 选择排序&#…

选择排序——Java排序算法

选择排序 选择排序&#xff08;SelectSort&#xff09;选择排序是所有排序中最简单的排序算法之一&#xff0c;同时也是要求我们必须掌握的排序算法之一。 时间复杂度 选择排序的时间复杂度为(n2) 算法步骤 1.在未排序的序列中找到最小或者最大的元素&#xff0c;存放到排…

java 排序api_JAVA排序算法API

上一个类 下一个类 框架 无框架 摘要&#xff1a; 嵌套 | 字段 | 构造函数 | 方法 详细信息&#xff1a; 字段 | 构造函数 | 方法 org.luosijin.test 类 Sort java.lang.Object org.luosijin.test.Sort public class Sort extends java.lang.Object Java实现几种常见排序方…

Java排序算法

7.1 排序算法的介绍 排序也称排序算法(Sort Algorithm)&#xff0c;排序是将一组数据&#xff0c;依指定的顺序进行排列的过程。 7.2 排序的分类 内部排序: 指将需要处理的所有数据都加载到内部存储器(内存)中进行排序。外部排序法&#xff1a; 数据量过大&#xff0c;无法全…

常见几种java排序算法

常见几种java排序算法 0. 总览时间复杂度和稳定性 1.插入排序2.分治排序法,快速排序法3.冒泡排序 low版4.冒泡排序 bigger版5.选择排序6. 归并排序8. 堆排序踩坑v1.0 巨慢不能用v2.0 太慢不能用v3.0 9. 其他排序7. 比较 0. 总览 时间复杂度和稳定性 平均最好最差稳定性冒泡n2…

Java常用实现八种排序算法与代码实现

一、交换排序 所谓交换&#xff0c;就是序列中任意两个元素进行比较&#xff0c;根据比较结果来交换各自在序列中的位置&#xff0c;以此达到排序的目的。 1. 冒泡排序 冒泡排序是一种简单的交换排序算法&#xff0c;以升序排序为例&#xff0c;其核心思想是&#xff1a; 从…

十大经典排序算法——java语言

文章目录 一、冒泡排序二、选择排序三、插入排序四、希尔排序五、归并排序六、快速排序七、堆排序八、计数排序九、桶排序十、基数排序 一、冒泡排序 概述&#xff1a; 冒泡排序是一种简单直观的排序算法。它重复的走访要排序的数列&#xff0c;一次比较两个元素&#xff0c;按…

Java常见排序算法

目录 1、归并排序 2、堆排序 3、基数排序 4、冒泡排序 5、希尔排序 6、快速排序 7、插入排序 8、选择排序 1、归并排序 1、基本思想 归并排序&#xff08;MERGE-SORT&#xff09;是利用归并的思想实现的排序方法&#xff0c;该算法采用经典的分治&#xff08;divide-a…

java实现七种经典排序算法

简单算法&#xff1a;冒泡&#xff0c;简单选择&#xff0c;直接插入 改进算法&#xff1a;希尔&#xff0c;堆&#xff0c;归并&#xff0c;快速 直接插入排序&#xff1a;将一个记录插入到已经拍好的有序列表中&#xff0c;从而得到一个新的、记录数增加1的有序表。 冒泡排…

java实现10种排序算法

1.冒泡排序(Bubble Sort) import java.util.Arrays; //冒泡排序 public class BubbleSort_01 {public static void main(String[] args) {int a[]{3,44,38,5,47,15,36,26,27,2,46,4,19,50,48};//记录比较次数int count0;//i0,第一轮比较for (int i 0; i < a.length-1; i) {…

SQL sever数据库触发器设计

SQL sever数据库触发器设计 一、目的: 能够理解触发器调用的机制。能够使用SQL命令创建DML触发器。能够完成触发器的修改、删除等管理任务。 二、触发器: 定义&#xff1a;触发器&#xff08; T rigger &#xff09;是 SQL server 提供给程序员和数据分析员来保证数据完整性…

MySQL——超详细数据库触发器教程

目录 一、触发器的概念 二、创建触发器 三、查看触发器 四、删除触发器 总结 一、触发器的概念 在实际开发中往往会碰到这样的情况&#xff1a; 当我们对一个表进行数据操作时&#xff0c;需要同步对其它的表执行相应的操作&#xff0c;正常情况下&#xff0c;如果我们使用…

关于数据库触发器(trigger)的简单使用操作

最近在做一些东西&#xff0c;用到关于数据库触发器的简单使用。比如当我们在做用户模块的表设计的时候&#xff0c;我们建了联用户信息表&#xff08;t_user&#xff09;和账号表&#xff08;t_account&#xff09;&#xff0c;账号表&#xff08;t_account&#xff09;用来进…

MySQL数据库触发器

MySQL 数据库中触发器是一个特殊的存储过程&#xff0c;不同的是执行存储过程要使用 CALL 语句来调用&#xff0c;而触发器的 执行不需要使用 CALL 语句来调用&#xff0c;也不需要手工启动&#xff0c;只要一个预定义的事件发生就会被 MySQL自动调用 引发触发器执行的事件一般…

mysql数据库触发器失效,mysql 的数据库触发器解决方法

mysql 的数据库触发器 我要做一个数据库触发器&#xff0c;当删除数据库中的某一张表的时候触发这个一个事件&#xff0c;删除其他表中的某一些数据。 大家给个例子 ------解决方案-------------------- MYSQL官方免费手册中已经有现成的例子了。 CREATE TABLE test1(a1 INT); …