直接插入排序的简单实现

一、过程演示

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)

稳定性: 稳定的排序

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

相关推荐
Frostnova丶2 小时前
LeetCode 1622. 奇妙序列
算法·leetcode
佩奇大王2 小时前
P1460 路径问题
java·开发语言
筱顾大牛2 小时前
Redission快速入门---分布式锁
java·redis·分布式·缓存
我真会写代码2 小时前
手写tomcat框架
java·servlet·tomcat
自在极意功。2 小时前
ArrayList扩容机制
java·开发语言·算法·集合·arraylist
Volunteer Technology2 小时前
核心框架源码常见问题(上)
java·后端·spring
吃鱼不吐刺.2 小时前
Java线程池
java·开发语言
小沛92 小时前
从“会敲 Arthas 命令”到“会做线上诊断”:我做了一个 Arthas Agent 工具
java·jvm·spring·agent
短剑重铸之日2 小时前
《ShardingSphere解读》04 配置驱动:ShardingSphere 中的配置体系是如何设计的?
java·数据库·后端·spring·shardingsphere