插入排序—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");
		}
		
		
	}
相关推荐
码猿技术专栏几秒前
Spring Integration 轻松实现服务间消息传递,真香!
java·spring boot
非ban必选7 分钟前
spring-ai-openai调用Xinference1.4.1报错
java·python·spring
学习2年半17 分钟前
equals() 和 hashCode()
java·开发语言·jvm
Dolphin_Home22 分钟前
微服务无感发布实践:基于Nacos的客户端缓存与故障转移机制
java·缓存·微服务
小黄人软件24 分钟前
PCI认证 密钥注入 ECC算法工具 NID_secp521r1 国密算法 openssl 全套证书生成,从证书提取公私钥数组 x,y等
算法·https·ssl
牛奶咖啡.85438 分钟前
树和图论(详细整理,简单易懂!)
数据结构·c++·算法·深度优先·图论
小周不摆烂43 分钟前
Java Web从入门到精通:全面探索与实战(二)
java
风象南1 小时前
SpringBoot中3种优雅停机的实现方式
java·spring boot·后端
2401_881244402 小时前
416. 分割等和子集
数据结构·算法
butterfly_onfly2 小时前
C# 多线程并发编程基础
数据结构·算法·c#