插入排序—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");
		}
		
		
	}
相关推荐
百锦再几秒前
国产数据库的平替亮点——关系型数据库架构适配
android·java·前端·数据库·sql·算法·数据库架构
爱笑的眼睛119 分钟前
文本分类的范式演进:从统计概率到语言模型提示工程
java·人工智能·python·ai
周杰伦_Jay21 分钟前
【Go/Python/Java】基础语法+核心特性对比
java·python·golang
sszdlbw23 分钟前
后端springboot框架入门学习--第一篇
java·spring boot·学习
晨曦夜月26 分钟前
笔试强训day5
数据结构·算法
小鹿学程序26 分钟前
jdk配置完之后java -version还是默认的jdk版本如何更改
java·开发语言·python
H_z___28 分钟前
Hz的计数问题总结
数据结构·算法
她说彩礼65万29 分钟前
C# 反射
java·算法·c#
练习时长一年30 分钟前
LeetCode热题100(搜索插入位置)
数据结构·算法·leetcode