插入排序 Insertion Sort
插入排序算法的运作如下:
通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。
插入排序算法的实现我放在这里。
时间/空间复杂度:
最差时间复杂度 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
最新文章
- [技术分享] centos如何挂载Windows共享文件
- 纯css制作带三角border篇(兼容所有浏览器)
- 【转载】UVa 11464 Even Parity 偶数矩阵
- Debian自带浏览器IceWeasel的中文化
- 在js自定义函数中使用$(event.target)代替$(this)
- 字体圆润属性的使用-webkit-font-smoothing: antialiased
- 有结果集的mysqli函数获取行数和列数
- python-认识Socket[入门篇]
- C# typeof() 和 GetType()区别
- Android简易实战教程--第六话《开发一键锁屏应用2·完成》
- requestAnimationFrame 知多少?
- QT杂记(网上资料整理而成)
- poj-2513(字典树+欧拉通路)
- jQuery.Deferred exception: $.get is not a function TypeError: $.get is not a function
- JS拖拽元素原理及实现代码
- Python(八)之函数
- Semantic segmentation using adversarial networks
- 使用vue2+Axios+Router 之后的总结以及遇到的一些坑
- Notepad++源代码阅读——窗口元素组织与布局
- IDA IDC Tutorials: Additional Auto-Commenting
热门文章
- First MFC
- 深入浅出--iOS的TCP/IP协议族剖析&;&;Socket
- bootstrap-table接合knockout.js
- 23:LVS客户端配置脚本案例
- djangoproject本地部署
- .Net 单例模式(Singleton)
- 在MathType中输入罗马数字的方法
- orm查询基本操作
- [JAVA &;#183; 0基础]:19.容器类
- [Spring Data MongoDB]学习笔记--注册一个Mongo实例