图解插入排序——直接插入排序算法(straight insertion sort)

简介: 图解插入排序——直接插入排序算法(straight insertion sort)

算法图解

直接插入排序,Straight Insertion Sort,是一种最简单的排序方法,它的基本思想就是把一个记录插入到一个有序的序列中,其基本步骤可以概括为两步:一是取出一个元素,留出空位;二是符合条件的元素右移,把取出的元素插入。那么这样的话,我们就需要一个辅助的变量来临时缓存这个被取出的变量,一般我们把这个辅助变量称之为“哨兵”。

第一趟插入排序:

因为是取出一个元素和前一个元素对比,根据大小关系决定插入到第一个元素的左边或者右边,所以第一趟排序应该从第二个元素开始,即i初始值为2。

假设给定一个序列{22, 11, 33, 10, 22},首先取出第二个元素11,用11和22比较,22大于11则22右移一位,然后把11插入到22的位置,即0号下标处。

在第一趟排序中,进行了一次比较,一次元素移动。通过第一趟排序形成了一个包含两元素的有序子序列。

第二趟插入排序:

取出第三个元素,第三个元素array[2]与第二个元素array[1]对比,若array[2]>array[1],那么就把array[2]插入到原处,即不进行任何操作,结束本趟插入排序;如果array[2]<array[1],那么array[1]右移一位,array[2]继续和array[0]比较;如果array[2]>array[0],那么array[2]插入到1号位置,结束本趟插入排序;如果array[2]<array[0],那么array[0]右移一位,array[2]插入到0号位置。

第二趟排序进行了一次比较,0次元素移动(这是最好的情况,即本来子序列就已经从小到大了)。经过第二趟排序,有序子序列加一,这也是插入法之所以称为插入的原因:把一个记录插入到一个有序的序列中。

第三趟插入排序:

取出第四个元素,执行比较-移动-插入三部曲操作。

第三趟排序,进行了三次比较,三次移动,这是最坏的情况,即每次比较都要移动。经过第三趟排序,有序序列再次加1,无序序列减一。

第n-1趟插入排序:

第n-1趟插入排序,将进行最少1次比较,0次移动;最多n-1次比较,n-1次移动。

且通过示意图可以看到,红色22本来就在黑色22前面,经过插入排序后,红色22依然在黑色22前面,所以插入排序是稳定排序。

算法实现(C语言)

1. /*交换 i j 位置的元素*/
2. void swap(int array[], int i, int j)
3. {
4.  int temp = array[i];
5.  array[i] = array[j];
6.  array[j] = temp;
7. }
8. 
9. /*插入排序*/
10. void insert_sort(int array[], int num)
11. {
12.   int i = 0, j = 0, Sentry = 0; /*Sentry 哨兵*/
13.   for (i = 1; i < num; i++)
14.   {
15.     Sentry = array[i]; /*取出一个元素*/
16.     j = i - 1;
17.     while ((j >= 0) && (Sentry < array[j]))
18.     {
19.       array[j + 1] = array[j]; /*符合条件右移*/
20.       j--;
21.     }
22.     array[j + 1] = Sentry;
23.   }
24. }

复杂度分析

拆入排序在最好的情况下,即数组本身就是按要求顺序排列好的,那么每趟插入排序都要进行一次比较,不需要移动元素,因为要n-1趟排序,所以共需要n-1次比较。在最坏的情况下,每趟排序都要进行比较,每次比较都要移动元素,比较次数为,移动次数也是如此,所以时间复杂度为

插入排序是一种,稳定的,时间复杂度为的,简单的内排序。

相关文章
|
2月前
|
算法 搜索推荐
数据结构与算法学习十一:冒泡排序、选择排序、插入排序
本文介绍了冒泡排序、选择排序和插入排序三种基础排序算法的原理、实现代码和测试结果。
24 0
数据结构与算法学习十一:冒泡排序、选择排序、插入排序
|
2月前
|
搜索推荐 算法
【排序算法(一)】——插入排序,选择排序 —> 深层解析
【排序算法(一)】——插入排序,选择排序 —> 深层解析
|
4月前
|
搜索推荐 算法 Java
现有一个接口DataOperation定义了排序方法sort(int[])和查找方法search(int[],int),已知类QuickSort的quickSort(int[])方法实现了快速排序算法
该博客文章通过UML类图和Java源码示例,展示了如何使用适配器模式将QuickSort类和BinarySearch类的排序和查找功能适配到DataOperation接口中,实现算法的解耦和复用。
55 1
现有一个接口DataOperation定义了排序方法sort(int[])和查找方法search(int[],int),已知类QuickSort的quickSort(int[])方法实现了快速排序算法
|
5月前
|
算法 搜索推荐 C#
|
6月前
|
机器学习/深度学习 算法 搜索推荐
数据结构算法--2 冒泡排序,选择排序,插入排序
**基础排序算法包括冒泡排序、选择排序和插入排序。冒泡排序通过相邻元素比较交换,逐步将最大值“冒”到末尾,平均时间复杂度为O(n^2)。选择排序每次找到剩余部分的最小值与未排序部分的第一个元素交换,同样具有O(n^2)的时间复杂度。插入排序则类似玩牌,将新元素插入到已排序部分的正确位置,也是O(n^2)复杂度。这些算法适用于小规模或部分有序的数据。**
|
6月前
|
算法 搜索推荐
数据结构与算法-插入排序
数据结构与算法-插入排序
35 2
|
6月前
|
算法 搜索推荐 数据可视化
【漫画算法】插入排序:插入宝石的传说
【漫画算法】插入排序:插入宝石的传说
|
6月前
|
人工智能 搜索推荐 JavaScript
心得经验总结:排序算法:插入排序法(直接插入法和希尔排序法)
心得经验总结:排序算法:插入排序法(直接插入法和希尔排序法)
49 0
|
6月前
|
机器学习/深度学习 搜索推荐 算法
【C/排序算法】:直接插入排序和希尔排序
【C/排序算法】:直接插入排序和希尔排序
50 0
|
6月前
|
搜索推荐 算法
排序算法之插入排序
排序算法之插入排序
56 0