【算法】插入排序的核心思路和代码实现

一、前言

在前两篇文章中,我们已经介绍了一些简单的排序算法,如选择排序、冒泡排序。今天,我们探讨另一种常见的简单排序算法------插入排序。

插入排序是一种直观且容易理解的排序算法,它的核心思想是将未排序的元素逐个插入到已排序的部分,以构建有序数组。


二、内容

2.1 思路

插入排序的思路非常直观,它模仿我们在现实生活中玩扑克牌的方式。当你拿到一副乱序的扑克牌,你会将每张牌插入到已经有序的手牌中,以确保手牌始终有序。插入排序的核心思想可以概括为以下几个步骤:

  1. 从数组的第二个元素开始,将其视为当前未排序区间的唯一元素。
  2. 比较当前元素与已排序区间的元素。
  3. 如果当前元素小于已排序区间的元素,将当前元素插入到适当的位置,同时将已排序区间的元素向后移动。
  4. 重复上述步骤,逐个将未排序区间的元素插入到已排序区间,直到整个数组有序。

演示动图如下:

2.2 步骤

具体而言,插入排序的步骤如下:

  1. 从数组的第二个元素开始,将其暂存为当前元素。
  2. 将当前元素与已排序区间的最后一个元素进行比较。
  3. 如果当前元素小于已排序区间的元素,将已排序区间的元素向后移动,直到找到当前元素应插入的位置。
  4. 将当前元素插入到适当的位置。
  5. 继续取下一个未排序区间的元素,重复上述过程,直到整个数组有序。

2.3 代码

下面是插入排序的Java代码实现:

使用两个for循环,将未排序的元素逐个插入到已排序的部分,以构建有序数组。

java 复制代码
public static void insertionSort(int[] arr) {
    if (arr == null || arr.length < 2) {
        return; // 如果数组为空或只有一个元素,无需排序
    }
    // 从第二个元素开始,依次插入到已排序区间
    for (int i = 1; i < arr.length; i++) {
        // 通过内层循环进行比较和交换元素,直到找到适当的插入位置
        for (int j = i - 1; j >= 0 && arr[j] > arr[j + 1]; j--) {
            swap(arr, j, j + 1);
        }
    }
}
private static void swap(int[] arr, int i, int j) {
    // 辅助方法,用于交换数组中指定下标的两个元素
    int temp = arr[i];
    arr[i] = arr[j];
    arr[j] = temp;
}

插入排序是一种稳定的排序算法,它的时间复杂度为 O( <math xmlns="http://www.w3.org/1998/Math/MathML"> n 2 n^2 </math>n2),其中n是数组的长度。与冒泡排序一样,插入排序也适用于小型数据集,但在某些情况下,它比冒泡排序更加高效。

三、总结

插入排序是一种直观且容易理解的排序算法,它的核心思想是将未排序的元素逐个插入到已排序的部分,以构建有序数组。尽管它的时间复杂度相对较高(O( <math xmlns="http://www.w3.org/1998/Math/MathML"> n 2 n^2 </math>n2)),但在某些情况下,特别是对于小型数据集,插入排序是一个合理的选择。

相关推荐
呼Lu噜3 分钟前
WPF-遵循MVVM框架创建图表的显示【保姆级】
前端·后端·wpf
bing_1588 分钟前
为什么选择 Spring Boot? 它是如何简化单个微服务的创建、配置和部署的?
spring boot·后端·微服务
学c真好玩21 分钟前
Django创建的应用目录详细解释以及如何操作数据库自动创建表
后端·python·django
Asthenia041221 分钟前
GenericObjectPool——重用你的对象
后端
Piper蛋窝31 分钟前
Go 1.18 相比 Go 1.17 有哪些值得注意的改动?
后端
excel1 小时前
招幕技术人员
前端·javascript·后端
盖世英雄酱581361 小时前
什么是MCP
后端·程序员
小鸡脚来咯2 小时前
SpringBoot 常用注解通俗解释
java·spring boot·后端
豌豆花下猫3 小时前
Python 3.14 t-string 要来了,它与 f-string 有何不同?
后端·python·ai