插入排序—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");
		}
		
		
	}
相关推荐
kuro-shiro2 分钟前
SpringBoot 启动流程
java·spring boot·后端
吴声子夜歌4 分钟前
SQL进阶——EXISTS谓词
java·数据库·sql
byte轻骑兵4 分钟前
【LE Audio】CSIP精讲[5]: 蓝牙协同设备组的安全防护体系与实战规范
算法·安全·音频·le audio·低功耗音频
偏爱自由 !5 分钟前
8. 泛型程序设计
java·开发语言·windows
剑挑星河月6 分钟前
35.搜索插入位置
java·数据结构·算法·leetcode
海兰7 分钟前
【SpringBoot 】AOP企业级权限控制方案(二)
android·java·spring boot
偏爱自由 !7 分钟前
2:IDEA中git的使用--基础操作
java·git·intellij-idea
ch.ju7 分钟前
Java Programming Chapter 4——Class loading
java·开发语言
LiaoWL1239 分钟前
【SpringBoot合集-03】Spring Boot 启动过程学习
java·spring boot·学习
闪电悠米16 分钟前
力扣hot100-438.找到字符串中所有字母异位词-固定长度滑动窗口详解
linux·服务器·数据结构·算法·leetcode·滑动窗口·力扣hot100