插入排序也是一种常见的排序算法,插入排序的思想是:
将初始数据分为有序部分和无序部分,每一步将一个无序部分的数据插入到前面已经排好序的有序部分中,直到插完所有元素为止。
一、插入排序基本原理
用一个索引值来区分两个区域 排序区 和 未排序区,将 未排序区元素 与 排序区元素 比较,并且插入到合适位置,直到未排序区清空
动画示例:
![](https://i-blog.csdnimg.cn/blog_migrate/7dd8e428a5187238935acec5aad02e99.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/5e09e3665deec9b0db65f4a770ea4879.png)
![](https://i-blog.csdnimg.cn/blog_migrate/b43b5448bf08a47e67a9f7c74bca8bc4.png)
二、实现代码
将一列数从左到右从小到大排列。
代码如下(示例):
private static int[] insertionSort(int[] array)
{
//遍历右边未排序区的数,n个数遍历n-1次(左边第一个默认已排序)
for (int unsorted = 1; unsorted < array.Length; unsorted++)
{
int temp = array[unsorted];//取下未排序区的第一个数
//从排序区的最后一个数开始依次往前
for (int sorted = unsorted - 1; sorted >= 0; sorted--)
{
if (temp < array[sorted])//找到目标位置,满足条件插入排序区
{
array[sorted + 1] = array[sorted];
array[sorted] = temp;
}
else
break;
}
}
return array;
}
注意:sorted >= 0是到第一个数为止,sorted--是从后往前。
---
总结
插入排序关键点:
两层循环,外循环代表有n个数进行n-1轮,内循环是将未排序区的数与已排序区的数从后往前依次比较。
稳定性:在使用插入排序时,元素从无序部分移动到有序部分时,必须是不相等(大于或小于)时才会移动,相等时不处理,所以直接插入排序是稳定的。
时间复杂度:插入排序在平均情况运行时间与最坏情况运行时间一样,是O(n^2)
适用性:待排序序列的元素个数不多(<=50),且元素基本有序。