迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 算法 >

排序算法的学习之路——插入排序(概念篇)

作者:迹忆 最近更新:2022/09/05 浏览次数:

何谓‘插入排序’? 其概念如是说:每次将一个待排序的记录,按其关键字大小插入到前面已经排序好的序列中,直到全部记录插入完成为止。

概念的东西总是有些抽象,也可称其为基本思想。上述插入排序的概念同样也可说是插入排序的基本思想。抽象的东西理解起来总是有些困难,因此这里需要的是将抽象的概念具体化。

我们不妨将其转换成整队问题:开始会有两队,其中一队是按从低到高的顺序排列的,将其命名为A队。另一队是无序的,将其命名为B队。如下图:

插入排序概念1

现在把B队的第一个人(不妨称其为jack)放到A队中,并且保持A队依然是有序的,为了保持A队依然有序就需要在A队中找一个适当的位置给jack,这个位置前面的人要比jack矮,后面的人要比jack高。现在就可以让jack站到这个位置上面,此时A中依然有序。

插入排序概念2

然后再把B队的第二个人(称其为tom)放到A队,方式和jack相同,要保证A队依然有序。

插入排序概念3

依次类推直到B队的人全部站到A队当中。到此为止,两队合成了一队,而且这一队是有序的。

插入排序概念4

看到这对插入排序应该有一个比较清晰的认识了。但是这里还存在着一个疑问,排序问题是对一个队列进行排序,何来的两队呢。我们不妨再来转换一下,起初的时候A、B两队站在同一列,并且A队整体在B队前面,并且A队是一个人。对于一个人的队列肯定是有序的。

插入排序概念5

然后再向代码方面靠近一下,不妨将A、B两队映射成数组。有这样一个数组

插入排序概念6

其中 3 就表示 刚开始的A队 ,5、2…. 表示刚开始的B队。而5 就是 Jack, 2 就是Tom。

我当时学习插入排序的时候就是按照这个思路来理解的。到这里我对插入排序的思想基本上已经完全掌握了。

思想的东西转换成代码,不同的方式也会产生不同的‘派系’。好比《春秋经》读起来总是有些难懂,这时就有人出来为春秋作传,不同的人作出来的传也是不同的,有《左传》,有《公羊传》,有《谷梁传》 。 虽然有所不同,但是整体都是传承的《春秋》的思想 。

现在回到我们的插入排序上来,既然思想的东西都已经明了了,无非就是实现方式的差别。关键的地方还是在于A队,当在A队为B队的人查找适当位置的时候,查找的方式有很多种。
    1、每次开始从头遍历查找位置 称其为 直接插入排序
    2、用二分法查找位置 称其为 二分插入排序/折半插入排序

以上两种方式 都是在一个队列中查找和移动元素,主要时间花费在查找和移动两个方面。
还有第三种方式就是借助额外的队列,来做一个映射,这样可以省去了移动所花费的时间。
就是用空间换时间的做法,这种方式被称为:
    3、表插入排序

这里面又涉及到了两个概念 时间复杂度 和 空间复杂度 在本篇不对这两个概念进行说明,我会在其他博文中来阐述一下我是如何理解这两个概念的。
由于篇幅问题本章不涉及到任何代码,仅仅分享一下自己对插入排序的理解。后续在其他的文章中为大家奉上本人写的每一种方法的实现代码。

上一篇:没有了

下一篇:排序算法的学习之路——直接插入排序

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

MATLAB 对行进行排序

发布时间:2023/04/23 浏览次数:198 分类:MATLAB

本教程将讨论使用 MATLAB 中的 sortrows() 函数对矩阵中存在的行进行排序。在数据分析和处理中,排序是必不可少的,因为它可以使数据在排序时易于分析和处理。

在 PHP 中使用 MongoDB 作为文件存储

发布时间:2023/04/20 浏览次数:132 分类:MongoDB

在为大文件创建可扩展存储方面,MongoDB 及其 GridFS(使用 MongoDB 查询语言 - MQL 编写)是市场上最好的文件存储解决方案之一。 在本教程中,您将学习如何在 PHP 中使用 MongoDB 作为文件存储。

在 Angular 中对表格进行排序

发布时间:2023/04/11 浏览次数:69 分类:Angular

我们可以按升序、降序等方式对表进行排序。现在让我们看看在 Angular 框架内创建具有排序功能的表的最佳方法。

在 C++ 中对字符串进行排序

发布时间:2023/03/31 浏览次数:102 分类:C++

本文演示了如何在 C++ 中对字符串进行排序。在本文中,我们假设字符序列存储在 std::string 对象中。

如何在 PHP 中获取时间差的分钟数

发布时间:2023/03/29 浏览次数:181 分类:PHP

本文介绍了如何在 PHP 中获取时间差的分钟数,包括 date_diff()函数和数学公式。它包括 date_diff()函数和数学公式。

PHP 中的重定向

发布时间:2023/03/29 浏览次数:133 分类:PHP

本教程演示了如何将用户从页面重定向到 PHP 中的其他页面

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便