Java排序算法(三):插入排序

传送门:Java排序算法汇总篇,八种排序算法

插入排序思想

插入排序的基本思想是: 把n个待排序的元素看成为一个有序表和一个无序表,开始时有序表中只包含一个元素,无序表中包含有n-1个元素,排序过程中每次从无序表中取出第一个元素,在有序表中从后往前进行比较,将它插入到有序表中的适当位置,使之成为新的有序表。

代码实现

复制代码
public class InsertSort1 {
    public static void main(String[] args) {
        int[] data = {1,1,2,8,4,2,1,6,4,8,6,9,2,1};
        sort(data);
        System.out.println(Arrays.toString(data));
    }

    public static void sort(int[] array){
        for (int i = 1; i < array.length; i++) {
            //temp取当前要插入的值
            int temp = array[i];
            //遍历temp前的值 大于temp就后移
            for (int j = i-1; j >=0; j--) {
                if(array[j]>temp){
                    //右移
                    array[j+1]=array[j];
                    array[j]=temp;
                }else {
                    break;
                }
            }
        }
    }
}
相关推荐
dragoooon34几秒前
[C++——lesson29.数据结构进阶——「AVL树」]
算法
碧海银沙音频科技研究院5 分钟前
论文写作word插入公式显示灰色解决办法
人工智能·深度学习·算法
Mr_Xuhhh7 分钟前
第一部分:类和对象(中)— 取地址运算符重载
java·开发语言
Selegant10 分钟前
告别传统部署:用 GraalVM Native Image 构建秒级启动的 Java 微服务
java·开发语言·微服务·云原生·架构
__万波__15 分钟前
二十三种设计模式(十三)--模板方法模式
java·设计模式·模板方法模式
动亦定15 分钟前
微服务中如何保证数据一致性?
java·数据库·微服务·架构
长沙京卓18 分钟前
【无人机算法】低空经济下无人机巡检检测识别算法(城市、林业、水利)
算法·无人机
hn小菜鸡19 分钟前
LeetCode 1971.寻找图中是否存在路径
算法·leetcode·职场和发展
王桑.20 分钟前
Spring中IoC的底层原理
java·后端·spring