插入排序—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");
		}
		
		
	}
相关推荐
東隅已逝,桑榆非晚13 小时前
深⼊理解指针(5)
c语言·笔记·算法
Gerardisite13 小时前
企业微信客户管理系统实战:标签、分层与自动化流程搭建
java·python·机器人·自动化·企业微信
ch.ju13 小时前
Java程序设计(第3版)第三章——数组的定义方式
java·开发语言
lwf00616413 小时前
顺序模型学习日记
算法
_日拱一卒13 小时前
LeetCode:199二叉树的右视图
算法·leetcode·职场和发展
The Chosen One98514 小时前
分享对dp题目的理解-不断更新ing
笔记·算法·深度优先·动态规划·dp
有时间要学习14 小时前
【无标题】
算法
Chloeis Syntax14 小时前
JavaEE学习日记(2)---文件操作和IO
java·笔记·学习·java-ee
无风听海14 小时前
OAuth 2.0 response_type完全指南
java·开发语言·oauth
re林檎14 小时前
算法札记——5.15
算法