插入排序(直接插入排序)java代码实现(注释详细 简单易懂)

简介: 插入排序(直接插入排序)java代码实现(注释详细 简单易懂)

直接插入排序算法思想:

以数组为例:

每次从未排序的数组中取出一个,与之前排好序的数组逐一比较大小,并插入到适当位置,直到未排序的数组为空。

时间复杂度O(n2).

java代码(注释写得比较详细,请认真看代码段的注释):

publicvoidtoInsertSort(int []arr) {
for(inti=1; i<arr.length;i++) {      //i是当前数for(intj=i-1 ; j>=0;j--) {      //j是从i-1开始向前移动,并每次与arr[i]判断大小if(arr[i]<arr[j]) {          //如果arr[i]小于arr[j]说明arr[i]当前至少是要插入到arr[j]的前面inttemp=arr[j];
arr[j] =arr[i];
arr[i] =temp;
i=j-1;             //互换后i也要向前移动一位            }
else{
break;              //直到arr[i]比arr[j]大,因为前面从小到大已经排好序,所以没有必要继续向前判断了                              }
        }
    }
}

希尔排序:

当然还有直接插入排序算法的改进算法希尔排序,

目录
相关文章
|
8月前
|
Java 开发工具
【Azure Storage Account】Java Code访问Storage Account File Share的上传和下载代码示例
本文介绍如何使用Java通过azure-storage-file-share SDK实现Azure文件共享的上传下载。包含依赖引入、客户端创建及完整示例代码,助你快速集成Azure File Share功能。
573 6
|
8月前
|
Java 数据处理 API
为什么你的Java代码应该多用Stream?从循环到声明式的思维转变
为什么你的Java代码应该多用Stream?从循环到声明式的思维转变
387 115
|
8月前
|
安全 Java 编译器
为什么你的Java代码需要泛型?类型安全的艺术
为什么你的Java代码需要泛型?类型安全的艺术
285 98
|
8月前
|
Java 编译器 API
java最新版和java8的区别,用代码展示
java最新版和java8的区别,用代码展示
679 43
|
8月前
|
安全 Java 容器
告别空指针噩梦:Optional让Java代码更优雅
告别空指针噩梦:Optional让Java代码更优雅
536 94
|
8月前
|
安全 Java 容器
告别繁琐判空:Optional让你的Java代码更优雅
告别繁琐判空:Optional让你的Java代码更优雅
|
9月前
|
IDE Java 关系型数据库
Java 初学者学习路线(含代码示例)
本教程为Java初学者设计,涵盖基础语法、面向对象、集合、异常处理、文件操作、多线程、JDBC、Servlet及MyBatis等内容,每阶段配核心代码示例,强调动手实践,助你循序渐进掌握Java编程。
1177 3
|
9月前
|
安全 Java 应用服务中间件
Spring Boot + Java 21:内存减少 60%,启动速度提高 30% — 零代码
通过调整三个JVM和Spring Boot配置开关,无需重写代码即可显著优化Java应用性能:内存减少60%,启动速度提升30%。适用于所有在JVM上运行API的生产团队,低成本实现高效能。
1083 3
|
9月前
|
Java
java入门代码示例
本文介绍Java入门基础,包含Hello World、变量类型、条件判断、循环及方法定义等核心语法示例,帮助初学者快速掌握Java编程基本结构与逻辑。
675 0