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;
                }
            }
        }
    }
}
相关推荐
就像风一样抓不住1 分钟前
Java 手机号校验工具类
java
lihihi9 分钟前
P9936 [NFLSPC #6] 等差数列
算法
凤山老林9 分钟前
26-Java this 关键字
java·开发语言
啊我不会诶14 分钟前
2024ICPC西安邀请赛补题
c++·算法
焦糖玛奇朵婷33 分钟前
解锁扭蛋机小程序的五大优势
java·大数据·服务器·前端·小程序
谭欣辰43 分钟前
C++ 版Dijkstra 算法详解
c++·算法·图论
yuan1999744 分钟前
C&CG(列与约束生成)算法,来解决“风光随机性”下的微网鲁棒配置问题
c语言·开发语言·算法
SamDeepThinking1 小时前
别让一个超时的第三方http接口拖垮所有接口
java·后端·架构
YaBingSec1 小时前
玄机靶场:供应链安全-供应链应急-Part2 通关笔记
java·笔记·安全
Gerardisite1 小时前
企微机器人开发指南
java·python·机器人·自动化·企业微信