首页 > 其他分享 >什么是插入排序

什么是插入排序

时间:2024-04-08 13:00:47浏览次数:26  
标签:arr 插入排序 元素 插入 key 排序 什么

一、什么是插入排序

插入排序是一种最简单的排序方法,其基本思想是将一个记录插入到已经排好序的有序表中,从而形成一个新的、记录数增1的有序表。其实现过程使用双层循环,外层循环对除了第一个元素之外的所有元素进行遍历,内层循环对当前元素前面有序表进行待插入位置查找,并进行移动

二、插入排序算法步骤

  1. 将第一个元素视为已经排序好的序列。
  2. 从第二个元素开始,逐个将待排序元素插入到已排序序列的合适位置,以保持已排序序列的有序性。
  3. 重复上述过程,直到所有元素都被插入到正确的位置,得到完整的有序序列。

三、插入排序的使用场景主要包括

  1. 数据量不大,数据局部有序或者整体有序的情况。因为在这种情况下,插入排序的效率较高,时间复杂度为O(n^2)。
  2. 算法稳定性要求高的情况。插入排序是一种稳定的排序方式,对于有相同元素的情况,插入排序能够保持它们的相对顺序不变。
  3. 对数据的插入操作频繁,需要经常进行插入排序的情况。插入排序的实现方式比较简单,适合于频繁进行插入和删除操作的场景。
  4. 数据规模较小,时间复杂度要求不高的情况。

四、什么时候会用到插入排序

  1. 小规模数据:由于插入排序的简单性和稳定性,适用于小规模数据的排序。
  2. 部分有序数据:当数据集合部分有序时,插入排序的表现较好,时间复杂度较低。
  3. 在线性表中插入元素时:如果需要在一个线性表中不断插入新元素并保持有序性,插入排序是个不错的选择

五、插入排序的知识点

  1. 稳定性:插入排序是一种稳定的排序算法,相同元素的相对位置在排序前后不会改变。
  2. 时间复杂度:平均情况下,插入排序的时间复杂度为 O(n^2),最好情况下为 O(n),最坏情况下为 O(n^2)。
  3. 空间复杂度:插入排序是一种原地排序算法,只需要常数级别的额外空间,空间复杂度为 O(1)。
  4. 高效性:在小规模数据或者部分有序数据的情况下,插入排序效率较高。

  1. 基本思想:将每个元素插入到已排序的部分的正确位置。
  2. 时间复杂度:最好情况下为,即数组已经有序;最坏情况下为,即数组逆序。
  3. 空间复杂度:为,因为它只使用了固定的额外空间。
  4. 稳定性:插入排序是一种稳定的排序算法,即相同的元素在排序前后的相对顺序保持不变。

六、Java语言实现插入排序

 以下是在Java中实现插入排序的示例代码:

public class InsertionSort {
    public static void insertionSort(int[] arr) {
        int n = arr.length;
        for (int i = 1; i < n; i++) {
            int key = arr[i];
            int j = i - 1;

            while (j >= 0 && arr[j] > key) {
                arr[j + 1] = arr[j];
                j--;
            }
            arr[j + 1] = key;
        }
    }

    public static void main(String[] args) {
        int[] arr = {12, 11, 13, 5, 6};
        System.out.println("排序前:" + Arrays.toString(arr));
        
        insertionSort(arr);
        
        System.out.println("排序后:" + Arrays.toString(arr));
    }
}

初始化变量 n 为数组的长度。

遍历数组,从第二个元素开始(i = 1),因为第一个元素默认是已排序的。

对于每个元素 arr[i],我们将其值保存在变量 key 中,以便于后面的比较和插入操作。

使用变量 j 来指向当前元素的前一个元素,即 arr[i-1]。

执行一个 while 循环,条件是 j 大于等于0,并且 arr[j](即当前元素的前一个元素)大于 key。这个循环的目的是找到 key 应该插入的位置。

在循环内部,将 arr[j] 的值移动到 arr[j+1] 的位置,为 key 腾出空间。

j 递减,继续向前比较,直到找到 key 应该插入的位置或者 j 变为负数(即没有更多的元素需要比较)。

当 while 循环结束时,j + 1 就是 key 应该插入的位置。因此,将 key 插入到 arr[j + 1]。

当所有元素都遍历完毕,数组也就完成了排序。

public static void insertionSort(int[] arr) {    
    int n = arr.length;  // 获取数组的长度  
  
    // 从数组的第二个元素开始遍历(因为第一个元素默认是有序的)  
    for (int i = 1; i < n; i++) {    
        // 当前要处理的元素,初始时我们假设它是未排序的  
        int key = arr[i];    
          
        // j用于指示已排序部分的最后一个元素的索引  
        int j = i - 1;    
  
        // 当j有效(非负)且已排序部分的元素大于key时,执行循环  
        while (j >= 0 && arr[j] > key) {    
            // 将已排序部分的元素后移,为key腾出空间  
            arr[j + 1] = arr[j];    
            // 将j向前移动一位,继续比较前一个元素  
            j--;    
        }  
          
        // 当循环结束时,j+1就是key应该插入的位置  
        // 将key插入到正确的位置  
        arr[j + 1] = key;    
    }    
}

标签:arr,插入排序,元素,插入,key,排序,什么
From: https://blog.csdn.net/2301_77523055/article/details/137504602

相关文章

  • 深度学习-卷积神经网络--什么是manifold embedding--66
    目录参考:流形假设(ManifoldHypothesis)在介绍流形学习(Manifoldlearning)之前,首先需要理解一个假设,就是流形假设(ManifoldHypothesis)。这个假设认为,高维数据很多都是低维流形嵌入(embedding)于高维空间当中,比如说三维空间里的各种平面或者曲面,虽然这些平面或者曲面处于三......
  • 常见的排序算法——插入排序(二)
    本文记述了插入排序微小改进的基本思想和一份参考实现代码,并在说明了算法的性能后用实验进行了验证。◆思想内存中的数据交换是昂贵的操作,此改进实现了不需要交换的插入排序。将第一个元素之后的所有元素作为待排序范围,将前面的所有元素作为已排序范围。通过一一比较,逐个将已......
  • 面试官:Zookeeper是什么,它有什么特性与使用场景?
    一、前言作为一名Java程序员,Zookeeper底层的一些原理是我们不必学会就可以搬砖工作的一种技能点,但是小奇为什么还要讲一下呢?难道就是为了浪费大家1分钟的宝贵时间,一个人1分钟,50万人就是1年,5000万人就是100年,赚了,小奇以一己之力成功搞挂一个人(血赚)。当然不是,并且小奇的文章......
  • 本地运行大模型,需要什么样的配置?
    本地运行大模型有多爽?只有用过了才知道。那是一种顺畅、自由的感觉。比如使用那些主流大模型,最常见的就是网络问题,如IP受限,或者服务器压力过大导致的延迟等等。使用本地大模型,真的是像和人自然交谈那么顺畅。而且,再也不用心疼token的费用了。使用API调用大模型时,......
  • 三种算法实例(二分查找算法、插入排序算法、贪心算法)
    当我们听到“算法”这个词时,很自然地会想到数学。然而实际上,许多算法并不涉及复杂数学,而是更多地依赖基本逻辑,这些逻辑在我们的日常生活中处处可见。在正式探讨算法之前,有一个有趣的事实值得分享:你已经在不知不觉中学会了许多算法,并习惯将它们应用到日常生活中了。下面我将举......
  • 什么是注意力机制?
    什么是注意力机制注意力机制(AttentionMechanism)是一种在深度学习模型中模拟人类注意力的技术。它的主要思想是,当我们处理一个任务时,我们不会平等地对待所有的信息,而是会将注意力集中在某些关键的部分。例如,当我们阅读一段文本时,我们会更关注与当前任务相关的词汇和句子,而忽略其......
  • 为什么苹果 Mac 电脑需要使用清理软件?
    尽管AppleMac电脑因其卓越的性能、简洁高效的macOS操作系统及独特的美学设计备受全球用户青睐,但任何电子设备在长期使用后都难以避免面临系统资源日渐累积的问题。其中一个重要维护需求在于,随着使用时间的增长,Mac电脑可能会由于系统垃圾文件、冗余数据、缓存积累等因素导......
  • 10:00面试,10:08就出来了,技术官问我什么是Containerd!
    10:00面试,10:08就出来了,技术官问我什么是Containerd!前言随着Dockershim在Kubernetes1.24版本中的弃用,社区和生态系统正在向容器运行时接口(CRI)的标准化迈进。在这样的转变中,containerd成为了Kubernetes推荐的默认容器运行时。本文将介绍containerd的概念、特点以......
  • 为什么Redis 是单线程的以及为什么这么快?
    redis完全基于内存,绝大部分请求是纯粹的内存操作,非常快速.数据结构简单,对数据操作也简单,redis中的数据结构是专门进行设计的采用单线程模型,避免了不必要的上下文切换和竞争条件,也不存在多线程或者多线程切换而消耗CPU,不用考虑各种锁的问题,不存在加锁,释放锁的操作......
  • HTTP错误代码大全,http网站状态码各代表了什么?
    响应码由三位十进制数字组成,它们出现在由HTTP服务器发送的响应的第一行。响应码分五种类型,由它们的第一位数字表示:1、1xx:信息,请求收到,继续处理2、2xx:成功,行为被成功地接受、理解和采纳3、3xx:重定向,为了完成请求,必须进一步执行的动作4、4xx:客户端错误,请求包含语法错误或者......