插入排序—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");
		}
		
		
	}
相关推荐
fengxin_rou18 小时前
黑马点评实战篇|第六篇:秒杀优化
java·开发语言·数据库·redis·分布式
后端AI实验室18 小时前
3年没人敢碰的老代码,我用AI重构了它——然后翻车了
java·ai
用户25656761334618 小时前
Binder 通信机制与 ANR 问题排查实战
java
ArturiaZ18 小时前
【day55】
数据结构·c++·算法
用户25656761334619 小时前
记一次诡异的 ANR 问题排查:主线程明明没干活,为啥还超时?
java
仰泳的熊猫19 小时前
题目2279:蓝桥杯2018年第九届真题-日志统计
数据结构·c++·算法·蓝桥杯
一叶落43819 小时前
LeetCode 11:盛最多水的容器(C语言实现)
c语言·数据结构·算法·leetcode
Emilin Amy19 小时前
一台具备了“观察力”的下肢康复外骨骼机器人
算法·机器人
I_LPL19 小时前
day53 代码随想录算法训练营 图论专题7
算法·图论
014-code19 小时前
Spring 事务原理深度解析
java·数据库·spring·oracle