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;
                }
            }
        }
    }
}
相关推荐
缺点内向几秒前
Java:轻松实现 Excel 文档属性添加
java·开发语言·excel
m0_692457102 分钟前
图像噪点消除
人工智能·算法
2401_841495643 分钟前
【Python高级编程】图着色动态可视化 APP
python·算法·matplotlib·tkinter·回溯法·图着色算法·动态可视化工具
pangtao20259 分钟前
【瑞萨RA × Zephyr评测】看门狗
java·后端·spring
HappyBoy_201921 分钟前
MybatisPlus IPage分页查询工具类
java·开发语言
youngee1126 分钟前
hot100-53搜索旋转排序数组
数据结构·算法·leetcode
小徐Chao努力27 分钟前
【Langchain4j-Java AI开发】10-框架集成(Spring Boot & Quarkus)
java·人工智能·spring boot
烟雨梵兮28 分钟前
-刷题小结19
算法
2501_9167665437 分钟前
【Java】final关键字
java·开发语言
C雨后彩虹39 分钟前
ConcurrentHashMap 核心锁机制:CAS+Synchronized 的协同工作原理
java·数据结构·哈希算法·集合·hashmap