《算法4》2.1 - 插入排序算法(Insertion Sort), Python实现
排序算法列表电梯:
**选择排序算法:详见 Selection Sort **
插入排序算法(Insertion Sort):非常适用于小数组和部分排序好的数组,是应用比较多的算法。详见本文
插入排序算法的语言描述:
大家都打过牌吧,理牌的时候,每人手里一把牌,一般都会按由大到小顺序排好,每抓一个新牌(比如 5),都会找到4和6,把6往后挪一下,然后把5插到4和6之间。
插入排序算法的原理与理牌是一样的,在一组未排序或部分排序的物体中,将物体从左到右挨个比较,每比较一次,将物体从小到大排好,每次比较后,前面几个物体都是排好序了的,后面的物体插入到前面已排好的序列,以此类推直到全部排序完毕。
这里的关键是,在前面已经排好序的数组中插入后面的物体,所以叫做插入排序。
插入排序算法的计算机语言描述
从一个 N 个数的数组或列表中,按从大到小或从小到大排序,排序的方法是:
1 确定是按从大到小还是从小到大排。(这里我们选择从小到大排序)
2 从小到大排的话,将第二个与第一个比较,如果小于第一个,则与第一个交换位置。反之不变。
4 将第三个与其前两个分别比较,如果小于则插入。
6 以此类推,直到最后一个。
要注意的是,插入的时候,需要把数组中待插部位的值往后挪哦。
插入排序算法的实现
这里用的是Python。
刚开始的时候为了突出理解插入的概念,用了个笨办法,显性的加了一步将数组值后挪的步骤,以便插入。后面会给出更简洁的代码。
算法实现代码(insertion_sort.py):
# -*- coding: utf-8 -*-
class InsertionSort(object):
items = []
def __init__(self,items):
self.items = items
def sort(self):
for i in range(0,len(self.items)-1):
temp = self.items[i]
if (self.items[i] < self.items[i-1]):
for j in range(0,i):
if (self.items[j] > temp):
for k in range (i,j,-1):
self.items[k] = self.items[k-1]
self.items[j] = temp
break;
上面的代码可以比较清晰的看到插入是如何工作的,但确实很傻,可以精简如下:
class InsertionSort_Refined(object):
items = []
def __init__(self,items):
self.items = items
def sort(self):
for i in range(0,len(self.items)-1):
j = i;
while (j > 0 and self.items[j] < self.items[j-1]):
self.items[j],self.items[j-1] = self.swap(self.items[j],self.items[j-1])
j -=1
def swap(self,i,j):
temp = j
j = i
i = temp
return i,j
测试代码:
# -*- coding: utf-8 -*-
import random
from timeit import default_timer as timer
from insertion_sort import InsertionSort
print "-"*10 + "sorting numbers" + "_"*10
items = []
for i in range(0,10):
items.append(random.randint(2,999))
print "original items: %r" % items
ssort = InsertionSort(items)
# calculate execution time for our selection sort method
start = timer()
ssort.sort()
end = timer()
duration1 = end - start
# calculate execution time for python built-in sort method
start = timer()
items.sort()
end = timer()
duration2 = end - start
assert ssort.items == items
print "sorted items: %r" % ssort.items
print "Duration: our insertion sort method - %ds, python builtin sort - %ds" % (duration1, duration2)
测试代码中,我们还用了python自带的sort方法,通过 "assert ssort.items == items" 一行语句是来验证我们的插入排序算法运行结果的正确性。并且加了timer,来比较我们的算法和python自带的sort方法的运行时间。
运行结果表明,排序的结果是一样的,和选择排序算法差不多,当数据量大的时候,运行性能比python自带的sort算法差很多。
运行结果示例(数组size=10):
----------sorting numbers__________
original items: [420, 373, 678, 818, 264, 30, 150, 310, 101, 833]
sorted items: [30, 101, 150, 264, 310, 373, 420, 678, 818, 833]
Duration: our insertion sort method - 0s, python builtin sort - 0s
插入排序算法分析
通过前面算法实现的例子,插入排序算法也是有性能问题的。
我们试着通过在算法中用到的比较次数和值交换次数来分析一下:
第二个与第一个比较时,需要比较 1 次,可能需要交换1次
第三个的时候,可能需要比较 2 次,可能需要交换2次
找最后一个值时,可能需要比较N-1次,可能需要交换N-1次
所以,最坏情况下,一共交换 1+2+...+(N-1) 次 = (N的平方)/2次,比较次数也是 1+2+...+(N-1) 次 = (N的平方)/2次。其复杂度已经不是线性的了。
但最好情况下,即数组已经是排序好了的,则只需要N-1次比较,无需任何交换。
所以,如果数组已经是部分或者全部排序过了,则使用插入排序算法无疑是不错的选择。
《算法4》2.1 - 插入排序算法(Insertion Sort), Python实现的更多相关文章
- 算法学习记录-排序——插入排序(Insertion Sort)
插入排序: 在<算法导论>中是这样描述的 这是一个对少量元素进行排序的有效算法.插入排序的工作机理与打牌时候,整理手中的牌做法差不多. 在开始摸牌时,我们的左手是空的,牌面朝下放在桌子上. ...
- 【算法】插入排序(Insertion Sort)
(PS:内容参考MIT算法导论) 插入排序(Insertion Sort): 适用于数目较少的元素排序 伪代码(Pseudocode): 例子(Example): 符号(notation): 时间复杂 ...
- 【算法】插入排序(Insertion Sort)(三)
插入排序(Insertion Sort) 插入排序(Insertion-Sort)的算法描述是一种简单直观的排序算法.它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相 ...
- 插入排序—直接插入排序(Straight Insertion Sort)
基本思想: 将一个记录插入到已排序好的有序表中,从而得到一个新,记录数增1的有序表.即:先将序列的第1个记录看成是一个有序的子序列,然后从第2个记录逐个进行插插入到已入,直至整个序列有序为止. 要点: ...
- 【排序基础】5、插入排序法 - Insertion Sort
插入排序法 - Insertion Sort 文章目录 插入排序法 - Insertion Sort 插入排序设计思想 插入排序代码实现 操作:插入排序与选择排序的比较 简单记录-bobo老师的玩转算 ...
- 直接插入排序(Straight Insertion Sort)
body, table{font-family: 微软雅黑; font-size: 13.5pt} table{border-collapse: collapse; border: solid gra ...
- 排序算法总结(一)插入排序【Insertion Sort】
最近在忙着找工作,以前看的排序算法都忘记了,悲剧啦T T现在来回顾一下吧. 这边推荐一个算法可视化的网站,非常有用.http://visualgo.net/ 一.插入排序的思想(Wikipedia) ...
- 【DS】排序算法之插入排序(Insertion Sort)
一.算法思想 一般来说,插入排序都采用in-place在数组上实现.具体算法描述如下:1)从第一个元素开始,该元素可以认为已经被排序2)取出下一个元素,在已经排序的元素序列中从后向前扫描3)如果该元素 ...
- 算法Sedgewick第四版-第1章基础-2.1Elementary Sortss-002插入排序法(Insertion sort)
一.介绍 1.时间和空间复杂度 运行过程 2.特点: (1)对于已排序或接近排好的数据,速度很快 (2)对于部分排好序的输入,速度快 二.代码 package algorithms.elementar ...
随机推荐
- 关于mysql的初步学习
1.在windows上使用CMD链接数据库 这是原始用户表 users 这是通过 语句插入而来的 user表和user2表结构相同 user2 的数据 通过如下SQL语句从users表赋值过来: in ...
- SpringMVC文件上传下载
不多说,代码: Spring-config.xml<!-- spring可以自动去扫描base-pack下面的包或者子包下面的java文件, 如果扫描到有Spring的相关注解的类,则把这些类注 ...
- Mysql安装设置建议(参数设置)
当我们监测MySQL性能时,人们希望我们能够检视一下MySQL配置然后给出一些提高建议.许多人在事后都非常惊讶,因为我们建议他们仅仅改动几个设置,即使是这里有好几百个配置项.这篇文章的目的在于给你一份 ...
- 感觉不止被Q了一下,还不知道被谁套了一个虚弱
最近身体出现了一些问题,导致博客无法正常更新,只能是看身体状态更新了,相信用不了半个月就会满血复活的,请谅解 Joker在这里提醒大家 身体是革命的本钱,不要透支,不要过度消耗
- bootstrap loadStep流程节点动态显示
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/ ...
- IE报vuex requires a Promise polyfill in this browser问题解决
使用Vuex, IE浏览器报错 因为使用了 ES6 中用来传递异步消息的的Promise,而IE低版本的浏览器不支持. ##解决方法 第一步: 安装 babel-polyfill . babel-po ...
- CF798 C. Mike and gcd problem
/* CF798 C. Mike and gcd problem http://codeforces.com/contest/798/problem/C 数论 贪心 题意:如果一个数列的gcd值大于1 ...
- unity还原three导出的json——基本模型,位移,旋转,缩放
GameObject.CreatePrimitive(PrimitiveType.Cube); GameObject.CreatePrimitive(PrimitiveType.Plane); Gam ...
- 前端框架对比之vue与regular(一)
每次一写到Regular总是忍不住先介绍一下,Regualr是网易杭州研究所的一位叫郑海波的大神写的一款前端框架,目前 这款框架推广的不深,加上其和angular过于相似的框架名,导致接受力并不大,其 ...
- MySQL索引及查询优化总结
欢迎大家关注腾讯云技术社区-博客园官方主页,我们将持续在博客园为大家推荐技术精品文章哦~ 作者:谢庆玲 文章<MySQL查询分析>讲述了使用MySQL慢查询和explain命令来定位mys ...