博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
算法-插入排序(Insertion sorting)
阅读量:5165 次
发布时间:2019-06-13

本文共 1167 字,大约阅读时间需要 3 分钟。

本文由原创,转载请注明出处。

 

简介:这是一个比较算法,形象的描述插入算法就和我们玩扑克的时候我们排列手牌的方式是一样的,最开始我们手上什么都没有,然后我们每摸一张牌就把它插入到正确的位置,直到所有的牌都排好序,这个排序算法是把一个数插入到已经排好序的序列中,让插入后的序列仍然保持有序,当一个序列只有一个数据时,这个序列当然是有序的,让后我们对每一个剩下的元素进行插入排序,保证新插入的数据在正确的位置,那么当所有的数据都插入的时候,序列就变得有序了,另外这个算法只适用于数据较少的排序。

 

思路:一般我们可以这样实现插入排序,把输入序列的第一个数当成只有一个数据的序列,那么它一定是有序的,然后将第二个数据用一个临时变量temp保存,这样原序列就有了一个"坑",然后我们用temp和所有的已经排好序的元素比较(目前就一个),从最大的数开始,把所有比temp大的数都向右滑动一位(看起来就像是那个"坑"一直在向左移动一样),直到遇到第一个比temp小的数 a,这时把temp放在"坑"现在所在的位置,也就是 a 的右边一位,这是新的数据就插入到了正确,然后我们对第三个数执行同样的操作,用temp保存起来...直到所有的数据都进行了这个过程,输入序列就变得有序了。

 

算法分析

平均时间复杂度:Θ(n2)

空间复杂度:O(1)

稳定性:稳定算法

是否是原址排序:是

 

代码实现

1 void insert_sort(vector
& v){ 2 int temp; 3 for (int i = 1; i < v.size(); ++i){
//从第二个数据开始 4 temp = v[i];//在数组中挖一个坑,将坑里的数据放在temp中 5 int j = i - 1; 6 while (j>0 && temp < v[j]){
//依次和坑前的数据对比,把所有比temp大的数往右挪一位(就像刚刚挖出来的坑一直在往左移动一样),直到遇到第一个比temp小的数,把temp放在这个数的右边 7 v[j + 1] = v[j]; 8 --j; 9 }10 v[j + 1] = temp;//安放temp11 }12 }

 

 

参考资料:《算法导论 中文版》(英文版第三版)(美)ThomasH.Cormen,CharlesE.Leiserson,RonaldL.Rivest,CliffordStein 著;王刚,邹恒明,殷建平,王宏志等译

转载于:https://www.cnblogs.com/coffeeSS/p/5430700.html

你可能感兴趣的文章
Java中反射的学习与理解(一)
查看>>
C语言初学 俩数相除问题
查看>>
B/S和C/S架构的区别
查看>>
[Java] Java record
查看>>
jQuery - 控制元素显示、隐藏、切换、滑动的方法
查看>>
postgresql学习文档
查看>>
Struts2返回JSON数据的具体应用范例
查看>>
js深度克隆对象、数组
查看>>
socket阻塞与非阻塞,同步与异步
查看>>
团队工作第二天
查看>>
System类
查看>>
tableView
查看>>
Happy Great BG-卡精度
查看>>
Xamarin Visual Studio不识别JDK路径
查看>>
菜鸟“抄程序”之道
查看>>
Ubuntu下关闭防火墙
查看>>
TCP/IP 邮件的原理
查看>>
原型设计工具
查看>>
windows下的C++ socket服务器(4)
查看>>
css3 2d转换3d转换以及动画的知识点汇总
查看>>