插入排序—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");
		}
		
		
	}
相关推荐
举一个梨子zz16 分钟前
Java—— IO流的应用
java·开发语言·intellij-idea·io·需求分析·file
星辰离彬17 分钟前
5.Java 面向对象编程入门:类与对象的创建和使用
java·开发语言·后端
猎板PCB厚铜专家大族28 分钟前
2025有铜半孔工艺参数设计规范
网络·算法·设计规范
yaoxin52112340 分钟前
85. Java Record 深入解析:构造函数、访问器、序列化与实际应用
java·开发语言
白熊1881 小时前
【图像大模型】AnimateDiff:基于扩散模型的视频生成技术解析与实践指南
人工智能·算法·音视频
辛普森Mmmm1 小时前
Spring boot和SSM项目对比
java·spring boot·spring
编程、小哥哥1 小时前
互联网大厂Java求职面试实录 —— 严肃面试官遇到搞笑水货程序员
java·面试·mybatis·dubbo·springboot·多线程·juc
2401_876907521 小时前
IEC 60034-30-1标准解析:旋转电机能效分级与全球影响
网络·数据结构·经验分享·科技·学习方法
滴水之功2 小时前
C语言数据结构-链式栈
linux·c语言·数据结构
少可爱2 小时前
对接钉钉消息样例:DING消息、机器人
java·开发语言·钉钉