插入排序—Java

插入排序

基本思想 :

  • 实现数组从小到大排
  • 从第二个数开始跟前面的数比较 找到合适的位置插入 后面的数往后推移 但推移不会超过原来插入的数的下标

代码实现

java 复制代码
public static void InsertSort(int[] arr) {
		for(int i = 1;i<arr.length;i++) {//从1开始是因为要和前面的数有一个比较的过程
			int InsertIndex=i-1;//要插入的理想目的地
			int Insertvalue= arr[i];
			while (InsertIndex>=0&&Insertvalue<arr[InsertIndex]) {
				//insertindex后移动一位
				arr[InsertIndex+1]=arr[InsertIndex];
				InsertIndex--;
				//一直在减去,所以while结束后代表找到
				//后面要加还给他,代表找到的那个位置
			}
		//
			if(InsertIndex+1!=i) {
				//+1代表找的那个位置
				arr[Insertvalue+1]=Insertvalue;
			}
		}
		for(int i = 0;i<arr.length;i++) {
			System.out.print(arr[i]+"\t");
		}
		
		
	}
相关推荐
j***63085 小时前
Spring Boot 多数据源解决方案:dynamic-datasource-spring-boot-starter 的奥秘(上)
java·spring boot·后端
z***67775 小时前
Spring Boot 实战:轻松实现文件上传与下载功能
java·数据库·spring boot
SKYDROID云卓小助手5 小时前
三轴云台之控制协同技术
服务器·网络·图像处理·人工智能·算法
q***01775 小时前
Java进阶学习之路
java·开发语言·学习
4***g8945 小时前
Spring Boot Admin 踩坑
java·spring boot·后端
s***35305 小时前
将 vue3 项目打包后部署在 springboot 项目运行
java·spring boot·后端
一辉ComeOn5 小时前
[源码系列:手写Spring] AOP第二节:JDK动态代理 - 当AOP遇见动态代理的浪漫邂逅
java·后端·spring
Zx623655 小时前
13.泛型编程 STL技术
java·开发语言·c++
The Last.H5 小时前
Educational Codeforces Round 185 (Rated for Div. 2)A-C
c语言·c++·算法
b***65325 小时前
SpringBoot的@Scheduled和@Schedules有什么区别
java·spring boot·spring