排序算法--插入排序

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.结果截图

相关推荐
2401_841495642 小时前
【计算机视觉】基于复杂环境下的车牌识别
人工智能·python·算法·计算机视觉·去噪·车牌识别·字符识别
Jonkin-Ma2 小时前
每日算法(1)之单链表
算法
晚风残3 小时前
【C++ Primer】第六章:函数
开发语言·c++·算法·c++ primer
杨云强3 小时前
离散积分,相同表达式数组和公式
算法
地平线开发者3 小时前
征程 6 | BPU trace 简介与实操
算法·自动驾驶
满天星83035773 小时前
【C++】AVL树的模拟实现
开发语言·c++·算法·stl
Lris-KK3 小时前
力扣Hot100--94.二叉树的中序遍历、144.二叉树的前序遍历、145.二叉树的后序遍历
python·算法·leetcode
麦麦鸡腿堡4 小时前
Java的动态绑定机制(重要)
java·开发语言·算法
zy_destiny4 小时前
【工业场景】用YOLOv8实现抽烟识别
人工智能·python·算法·yolo·机器学习·计算机视觉·目标跟踪
坚持编程的菜鸟4 小时前
LeetCode每日一题——螺旋矩阵
c语言·算法·leetcode·矩阵