直接插入排序的简单实现

一、过程演示

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)

稳定性: 稳定的排序

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

相关推荐
田梓燊1 天前
力扣:23.合并 K 个升序链表
算法·leetcode·链表
invicinble1 天前
这里对java的知识体系做一个全域的介绍
java·开发语言·python
wbs_scy1 天前
【Linux 线程进阶】进程 vs 线程资源划分 + 线程控制全详解
java·开发语言
re林檎1 天前
算法札记——4.27
算法
ss2731 天前
食谱推荐系统功能测试如何写?
java·数据库·spring boot·功能测试
AI人工智能+电脑小能手1 天前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
数据牧羊人的成长笔记1 天前
逻辑回归与Softmax回归
算法·回归·逻辑回归
try2find1 天前
打印ascii码报错问题
java·linux·前端
014-code1 天前
CompletableFuture 实战模板(超时、组合、异常链处理)
java·数据库
Nicander1 天前
多数据源下@transcation事务踩坑
java·后端