插入排序算法的运作如下:  

  通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。

  插入排序算法的实现我放在这里

时间/空间复杂度:

  最差时间复杂度 O(n^2)

  最优时间复杂度 O(n)

  平均时间复杂度 O(n^2)

  空间复杂度 需要辅助空间O(1), 因此插入排序为原地排序.

  如果目标是把n个元素的序列升序排列,那么采用插入排序存在最好情况和最坏情况。最好情况就是,序列已经是升序排列了,

在这种情况下,需要进行的比较操作需(n-1)次即可。最坏情况就是,序列是降序排列,那么此时需要进行的比较共有n(n-1)/2次。

插入排序的赋值操作是比较操作的次数加上(n-1)次。平均来说插入排序算法复杂度为O(n^2)。因而,插入排序不适合对于数

据量比较大的排序应用。但是,如果需要排序的数据量很小,例如,量级小于千,那么插入排序还是一个不错的选择。 插入排序在

工业级库中也有着广泛的应用,在STL的sort算法和stdlib的qsort算法中,都将插入排序作为快速排序的补充,用于少量元素的排

序(通常为8个或以下)。

注:

"插入排序的赋值操作是比较操作的次数加上(n-1)次", 对于这句话,我的理解是,对于每一个元素的处理:首先把要处理的元素指保存

起来(赋值一次,保存到一个变量中),之后每一个比较操作都会对应一个赋值操作, 所以对于每一个元素的处理,复制操作比比较操作多

一次。又由于有n-1个元素需要进行处理, 所以"插入排序的赋值操作是比较操作的次数加上(n-1)次"。

网上(wikipedia)对于这句话也有另外的说法"插入排序的赋值操作是比较操作的次数减去(n-1)次"。不知是wikipedia上的错误还是

有另外的理解和说法。如果有人知道,还望不吝赐教。

算法稳定性:

  插入排序是稳定的。

Reference:

插入排序-wikipedia: http://zh.wikipedia.org/wiki/%E6%8F%92%E5%85%A5%E6%8E%92%E5%BA%8F

最新文章

  1. [技术分享] centos如何挂载Windows共享文件
  2. 纯css制作带三角border篇(兼容所有浏览器)
  3. 【转载】UVa 11464 Even Parity 偶数矩阵
  4. Debian自带浏览器IceWeasel的中文化
  5. 在js自定义函数中使用$(event.target)代替$(this)
  6. 字体圆润属性的使用-webkit-font-smoothing: antialiased
  7. 有结果集的mysqli函数获取行数和列数
  8. python-认识Socket[入门篇]
  9. C# typeof() 和 GetType()区别
  10. Android简易实战教程--第六话《开发一键锁屏应用2·完成》
  11. requestAnimationFrame 知多少?
  12. QT杂记(网上资料整理而成)
  13. poj-2513(字典树+欧拉通路)
  14. jQuery.Deferred exception: $.get is not a function TypeError: $.get is not a function
  15. JS拖拽元素原理及实现代码
  16. Python(八)之函数
  17. Semantic segmentation using adversarial networks
  18. 使用vue2+Axios+Router 之后的总结以及遇到的一些坑
  19. Notepad++源代码阅读——窗口元素组织与布局
  20. IDA IDC Tutorials: Additional Auto-Commenting

热门文章

  1. First MFC
  2. 深入浅出--iOS的TCP/IP协议族剖析&&Socket
  3. bootstrap-table接合knockout.js
  4. 23:LVS客户端配置脚本案例
  5. djangoproject本地部署
  6. .Net 单例模式(Singleton)
  7. 在MathType中输入罗马数字的方法
  8. orm查询基本操作
  9. [JAVA · 0基础]:19.容器类
  10. [Spring Data MongoDB]学习笔记--注册一个Mongo实例