排序算法-插入排序

属性

当插入第i(i>=1)个元素时,前面的array0,array1,...,arrayi-1已经排好序,此时用arrayi的排序码与arrayi1,arrayi-2,...的排序码顺序进行比较,找到插入位置即将arrayi插入,原来位置上的元素顺序后移

直接插入排序的特性总结: 1. 元素集合越接近有序,直接插入排序算法的时间效率越高 2. 时间复杂度:O(N^2) 3. 空间复杂度:O(1),它是一种稳定的排序算法 4. 稳定性:稳定

代码及其注释

java 复制代码
public class InsertSort {
    // 插入排序
    public static void insertSort(int[]arr){
        //首先比较第一个元素和第二个元素之间的大小关系,所以i从1开始
        for(int i=1;i<arr.length;i++){
            //将要进行比较的数放到一个临时变量中,此时就相当于i位置现在是空的
            int tmp=arr[i];
            //遍历i前面的数据,与temp中的数据进行比较
            int j=i-1;
            for(;j>=0;j--){
                //要是i前面的数据比i的数据大,就说明该数据应该在i数据之前,就将该数据向前移
                if(arr[j]>tmp){
                    arr[j+1]=arr[j];
                }
                //i前面的数据比i的数据小了,找到了合适的位置,就退出循环并将i的数据放到当前遍历到的j数据之前
                else {
                    break;
                }
            }
            //这里有特殊情况,当i前面的数据都比i大时,j的取值会一直取到-1,退出循环,此时就需要将i的值放到0的位置
            arr[j+1]=tmp;
        }
    }
}
相关推荐
逸Y 仙X5 分钟前
文章五:Elasticsearch安全通信
java·大数据·安全·elasticsearch·搜索引擎·全文检索·jenkins
quan263115 分钟前
20260529,日常开发-查老数据全量更新闭坑
java·mysql·主从·主从延迟
大大杰哥17 分钟前
Java 日志框架详解:SLF4J + Logback 从入门到实战
java·开发语言·logback
莫等闲-25 分钟前
leetcode42. 接雨水 leetcode84.柱状图中最大的矩形
数据结构·c++·算法·leetcode
unicrom_深圳市由你创科技25 分钟前
历史数据存储量太大,怎么处理?数据压缩/归档策略?
算法
浅念-26 分钟前
LeetCode 记忆化搜索 刷题总结
数据结构·算法·leetcode·职场和发展·深度优先·dfs
Dest1ny-安全31 分钟前
2026最新CTF知识库:12大Web漏洞深度文章+1156篇历年大赛WP+50+脚本+Payload速查 +AI/RAG离线在线知识库
java·学习·安全·web安全·servlet
404号扳手31 分钟前
Java 基础知识(六)
java·后端
菜菜的顾清寒40 分钟前
力扣HOT100(44)对称二叉树
数据结构·算法·leetcode
吃好睡好便好1 小时前
矩阵的左乘和右乘
人工智能·学习·线性代数·算法·matlab·矩阵