插入排序:一种简单而直观的排序算法

news/2025/2/25 12:02:35

大家好!今天我们来聊聊一个简单却非常经典的算法>排序算法——插入排序(Insertion Sort)。在所有的算法>排序算法中,插入排序是最直观的一个。

一、插入排序的基本思想

插入排序的核心思想是:将一个待排序的元素,插入到已排好序的部分中,使得插入后的部分依然是有序的。

具体来说,插入排序会从数组的第二个元素开始,逐步与前面的元素进行比较,并将其插入到合适的位置,直到整个数组都排序完成。

举个例子:

  1. 假设我们有一个数组 [5, 3, 8, 4, 2],我们从第二个元素开始,逐个与前面的元素进行比较。
  2. 第一次比较,我们将 35 比较,发现 3 小于 5,就将 3 插入到 5 的前面,数组变成 [3, 5, 8, 4, 2]
  3. 第二次比较,将 8 与前面的元素逐一比较,发现它已经大于 5,不需要移动。
  4. 继续这个过程,直到整个数组都变得有序。

二、插入排序的步骤

  1. 从第二个元素开始遍历,逐个元素插入到已排好序的部分。
  2. 对于每个元素,向前比较,直到找到合适的位置为止。
  3. 插入的操作可以通过移动元素的位置来完成,使得原来位置较大的元素腾出位置来插入新的元素。

三、插入排序的实现

我们通过 Java 来实现插入排序,看看这个过程是如何完成的。

java">public static void InsertSort(int[] arr) {
        //i待插入数据下标
        for (int i = 1; i < arr.length; i++) {
            //j为已排序部分最后一个元素,即待排序元素的前一个元素,使j与j+1比较,j大交换,j小结束
            for (int j = i - 1; j >= 0; j--) {
                if (arr[j] > arr[j + 1]) {
                    int temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                } else{
                    break;
                }
            }
        }
    }

四、插入排序的时间复杂度

插入排序的时间复杂度主要取决于待排序数据的顺序。

  • 最优情况:当数组已经是有序的时,内层循环不会执行任何移动操作,因此时间复杂度是 O(n),其中 n 是数组的长度。

  • 最坏情况:当数组是逆序时,每次插入都需要将元素移动到数组的前面,这时内层循环会执行 i 次移动操作。因此时间复杂度是 O(n²)

  • 平均情况:假设元素是随机排列的,平均情况下,时间复杂度也为 O(n²)

五、插入排序的优缺点

优点:
  1. 简单直观:插入排序的实现非常简单,而且非常适合小规模数据的排序。
  2. 稳定性:插入排序是稳定的算法>排序算法,即相等的元素不会交换位置。
  3. 适用于部分有序的数组:当数组已经接近有序时,插入排序会表现得非常高效。
缺点:
  1. 时间复杂度高:在数据规模较大的时候,插入排序的效率较低,特别是在最坏情况下,时间复杂度达到 O(n²)
  2. 不适合大规模数据:对于大数据量的排序,插入排序不是最优选择。其他更高效的算法>排序算法(如快速排序、归并排序)通常会更适用。

六、插入排序的应用场景

尽管插入排序在大规模数据中效率较低,但在一些特殊场景下,它依然非常有用:

  1. 小规模数据排序:在数据量较小的情况下,插入排序非常高效且简单。
  2. 部分有序的数组:如果数据已经部分有序,插入排序可以大大减少排序的工作量。
  3. 在线算法:插入排序是一种在线算法,也就是说它可以逐步地接收新的数据并进行排序。例如在实时排序数据流时,可以使用插入排序。

http://www.niftyadmin.cn/n/5865474.html

相关文章

独立开发者Product Hunt打榜教程

Product Hunt 是创业者和开发者展示新产品的地方&#xff0c;对于独立开发者来说&#xff0c;打榜不仅仅是展示产品的良机&#xff0c;更是提高品牌知名度和获取早期用户的重要途径。以下是独立开发者如何在Product Hunt上打榜的详细教程&#xff1a; 1. 产品准备阶段 确保产…

conda 基本命令

1、查询当前所有的环境 conda env list 2、创建虚拟环境 conda create -n 环境名 [pythonpython版本号] 其中[pythonpython版本号]可以不写 conda create -n test python3.12 我们输入conda env list看到我们的环境创建成功了&#xff0c;但是发现他是创建在我们默认的C盘的…

基础知识3

文章目录 MySQL的执行引擎有哪些&#xff1f;1. **InnoDB**2. **MyISAM**3. **Memory**4. **Archive**5. **CSV**6. **Blackhole**7. **Federated**8. **NDB Cluster**9. **其他存储引擎**总结 MySQL为什么使用B树来作索引1. **InnoDB**2. **MyISAM**3. **Memory**4. **Archive…

Threejs教程三【揭秘3D贴图魔法】

定义 贴图&#xff08;Texture&#xff09;是 Three.js 中用于为物体表面添加纹理的一种技术。它可以将图像、视频或其他类型的媒体映射到物体的表面&#xff0c;使其看起来更加真实和生动。 基本原理 贴图的基本原理是将图像或视频映射到物体的表面&#xff0c;使其看起来更…

[java基础-JVM篇]3_JVM类加载机制

摘要&#xff1a;JVM通过设立不同优先级和职责的加载器保证了类加载的安全性与灵活性&#xff0c;即双亲委派机制&#xff0c;但是实际生产中更复杂的需求又需要破坏双亲委派&#xff0c;即打破JVM约定过的类加载程序 目录 类的生命周期 类加载 加载 类加载器 双亲委派机制…

EX_25/2/22

找到第一天mystring练习&#xff0c;实现以下功能 mystring str "hello" mystring ptr "world" str str ptr; str ptr str[0] H #include <iostream> #include <cstring> #include <cstdlib> #include <unistd.h> #in…

JMeter性能问题

性能测试中TPS上不去的几种原因 性能测试中TPS上不去的几种原因_tps一直上不去-CSDN博客 网络带宽 连接池 垃圾回收机制 压测脚本 通信连接机制 数据库配置 硬件资源 压测机 业务逻辑 系统架构 CPU过高什么原因 性能问题分析-CPU偏高 - 西瓜汁拌面 - 博客园 US C…

选择排序:简单高效的选择

大家好&#xff0c;今天我们来聊聊选择排序&#xff08;Selection Sort&#xff09;算法。这是一个非常简单的排序算法&#xff0c;适合用来学习排序的基本思路和操作。选择排序在许多排序算法中以其直观和易于实现的特点著称&#xff0c;虽然它的效率不如其他高效算法&#xf…