排序算法--插入排序

1.原理

整个数列分成两部分:第一部分是已经排好序的数列,第二部分是未排序的数列

在未排序的数列中找出一个哨兵,看它应该在 已经排好序的数列中的哪个位置,进行插入

2.代码

java 复制代码
public class 插入排序 {
	public static void main(String[] args) {
		int a[]= {2,2,1,6,4,9,6,8};
		for(int i=1;i<a.length;i++) {
			int k=a[i];// 哨兵,从数组第二位元素开始,每次循环向后移动一位
			//将这个数插入到前面排好序的数列中
			int j=i-1;//排好序的数列中的最后一位
			while(j>=0&&k<a[j]) {
				a[j+1]=a[j];//给哨兵的插入腾位置
				j--;//j 记录哨兵最终插入的位置
			}
			a[j+1]=k;	
		}
		for(int i=0;i<a.length;i++) {
			System.out.print(a[i]+" ");
	     }
	}
}

3.结果截图

相关推荐
sin_hielo1 小时前
leetcode 2872
数据结构·算法·leetcode
dragoooon342 小时前
[优选算法专题八.分治-归并 ——NO.49 翻转对]
算法
AI科技星2 小时前
为什么宇宙无限大?
开发语言·数据结构·经验分享·线性代数·算法
Zero-Talent3 小时前
位运算算法
算法
不穿格子的程序员3 小时前
从零开始刷算法——双指针-三数之和&接雨水
算法·双指针
无限进步_4 小时前
C语言数组元素删除算法详解:从基础实现到性能优化
c语言·开发语言·windows·git·算法·github·visual studio
松涛和鸣4 小时前
16、C 语言高级指针与结构体
linux·c语言·开发语言·数据结构·git·算法
Booksort4 小时前
【LeetCode】算法技巧专题(持续更新)
算法·leetcode·职场和发展
OJAC1114 小时前
2026高校毕业生1270万!但这些学生却被名企用高薪“提前预定”!
算法
Controller-Inversion4 小时前
岛屿问题(dfs典型问题求解)
java·算法·深度优先