直接插入排序的简单实现

一、过程演示

i 从 1 开始,j 从 i - 1 开始

把 array i 的值记录在 temp 里

当array j 的值大于 temp,将array j 的值赋给 array j + 1,然后 j - -

当 array j 的值小于 temp 时,把temp 的 值 赋给array j + 1,还有一种情况是当j 为 0,

array j + 1 = temp;

然后后续重复这个过程

二、代码实现

java 复制代码
    public static void insertSort(int[] arr) {
        for(int i = 1; i < arr.length; i++) {
            int temp = arr[i];
            int j = i - 1;
            for(; j >= 0; j--) {
                if(arr[j] > temp) {
                    arr[j + 1] = arr[j];
                }else{
                    arr[j + 1] = temp;
                    break;
                }
            }
            arr[j + 1] = temp;
        }
    }

时间复杂度:O(n^2)

空间复杂度: O(1)

稳定性: 稳定的排序

插入排序有一个特点,数据越有序,速度越快

相关推荐
地平线开发者8 小时前
J6B vio scenario sample
算法
Flittly16 小时前
【AgentScope Java新手村系列】(16)从RAG到多路检索
java·spring boot·spring
小兔崽子去哪了16 小时前
Java 生成二维码解决方案
java·后端
BothSavage20 小时前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn20 小时前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
人活一口气20 小时前
从JVM调优到MCP协议:Java全栈技术体系深度总结与企业级架构实践
java·spring boot
烬羽1 天前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
NE_STOP1 天前
Vibe Coding -- 完整项目案例实操
java
荣码1 天前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python