LowB三人组--插入排序原理和java实现

简介: LowB三人组--插入排序原理和java实现


插入排序原理图

https://www.runoob.com/w3cnote/insertion-sort.html

java实现代码

/**
 * 插入排序
 */
public class InsertionSortTest {
    public static void main(String[] args) {
        int[] arr = {2,4,7,5,3,6,8,9,1};
        insertionSort(arr);
    }
    /**
     * 插入排序的原理:
     * 将待排序数组看成两部分: 有序数组和无序数组,初始时,第一次可以将第一张看成有序数组,其余作为无序数组
     *  无序数组插入到有序数组中,遍历无序数组(无序数组个数就是需要插入的次数)
     *      将有序数组的右侧第一张和 无序的第一张,
     *         如果 从有序的右侧起: 获取无序的元素小于于有序的元素的第一个元素的索引,有序的这些元素向右移动一位
     *                           同时当前的索引值+1的位置就是 插入的元素
     */
    public static void insertionSort(int[] arr){
        //外层为 要插入的元素
        for (int i=1;i<arr.length;i++){
            //有序位置的最后一个元素
            int tmp = arr[i];
            //获取要插入的元素的位置
            int j = i - 1;
            //从右侧起,获取第一个比要插入的元素小的元素的索引,索引右侧的值 右移一位
            while (j>=0 && arr[j]  > tmp){
                arr[j+1] = arr[j];
                //arr[j] = tmp;
                j--;
            }
            arr[j+1] = tmp;
            System.out.println(Arrays.toString(arr));
        }
    }
}

运行结果:

复杂度


相关文章
|
2天前
|
存储 安全 Java
【Java EE】CAS原理和实现以及JUC中常见的类的使用
【Java EE】CAS原理和实现以及JUC中常见的类的使用
|
4天前
|
设计模式 消息中间件 Java
Java 设计模式:探索发布-订阅模式的原理与应用
【4月更文挑战第27天】发布-订阅模式是一种消息传递范式,被广泛用于构建松散耦合的系统。在 Java 中,这种模式允许多个对象监听和响应感兴趣的事件。
21 2
|
6天前
|
安全 Java 开发者
Java编程:深入探索其原理、特性与实战代码
Java编程:深入探索其原理、特性与实战代码
10 1
|
13天前
|
Java 调度
《Java 多线程实战系列》- 01 基本概念与底层原理
《Java 多线程实战系列》- 01 基本概念与底层原理
15 0
|
17天前
|
Java API 微服务
Java微服务架构:原理与实践
【4月更文挑战第15天】本文介绍了Java微服务架构的原理和实践,包括服务拆分、注册与发现、API网关、配置中心和分布式链路追踪。重点提及Spring Boot和Spring Cloud作为开发工具,以及Docker和Kubernetes用于容器化和集群管理。Java微服务架构旨在应对大规模、复杂业务系统的挑战,提升系统可用性和可扩展性。
|
Java Android开发
【Java 虚拟机原理】Java 引用类型 ( 强引用 | 软引用 | 弱引用 | 虚引用 | 静态变量 )
【Java 虚拟机原理】Java 引用类型 ( 强引用 | 软引用 | 弱引用 | 虚引用 | 静态变量 )
127 0
|
1天前
|
缓存 Java 调度
Java并发编程:深入理解线程池
【4月更文挑战第30天】 在Java并发编程中,线程池是一种重要的工具,它可以帮助我们有效地管理线程,提高系统性能。本文将深入探讨Java线程池的工作原理,如何使用它,以及如何根据实际需求选择合适的线程池策略。
|
1天前
|
Java
Java并发编程:深入理解线程池
【4月更文挑战第30天】 本文将深入探讨Java中的线程池,解析其原理、使用场景以及如何合理地利用线程池提高程序性能。我们将从线程池的基本概念出发,介绍其内部工作机制,然后通过实例演示如何创建和使用线程池。最后,我们将讨论线程池的优缺点以及在实际应用中需要注意的问题。
|
1天前
|
设计模式 算法 安全
Java多线程编程实战:从入门到精通
【4月更文挑战第30天】本文介绍了Java多线程编程的基础,包括线程概念、创建线程(继承`Thread`或实现`Runnable`)、线程生命周期。还讨论了线程同步与锁(同步代码块、`ReentrantLock`)、线程间通信(等待/通知、并发集合)以及实战技巧,如使用线程池、线程安全设计模式和避免死锁。性能优化方面,建议减少锁粒度和使用非阻塞算法。理解这些概念和技术对于编写高效、可靠的多线程程序至关重要。
|
1天前
|
Java 调度 开发者
Java中的多线程编程:基础知识与实践
【4月更文挑战第30天】 在现代软件开发中,多线程编程是提高程序性能和响应能力的关键。Java作为一款广泛使用的编程语言,提供了丰富的多线程支持。本文将介绍Java多线程的基础概念、实现方法以及常见问题的解决策略。我们将从线程的创建和管理入手,逐步深入到同步机制、死锁避免以及高级并发工具类的应用。通过实例代码演示和理论分析,旨在帮助读者掌握Java多线程编程的核心技能,提升软件项目的并行处理能力。