直接插入排序的简单实现

一、过程演示

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)

稳定性: 稳定的排序

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

相关推荐
8Qi82 小时前
回文子串(Palindromic Substrings)—— 题解
算法·leetcode·职场和发展·动态规划
二月夜4 小时前
剖析Java正则表达式回溯问题
java·正则表达式
xuhaoyu_cpp_java5 小时前
项目学习(三)分页查询
java·经验分享·笔记·学习
程序员二叉5 小时前
【Java】集合面试全套精讲|HashMap/ArrayList高频考点完整版
java·面试·哈希算法
cfm_29146 小时前
JVM GC垃圾回收初步了解
java·开发语言·jvm
心之伊始6 小时前
LangChain4j RAG 实战:Java 后端如何把本地文档接入 Embedding 检索链路
java·架构·源码分析·csdn
许彰午6 小时前
17_synchronized关键字深度解析
java·开发语言
小宋加油啊7 小时前
机械臂抓取物体 PVN3D算法调研学习
学习·算法·3d
lqqjuly7 小时前
前沿算法深度解析(一)
算法