python插入排序算法总结
插入排序算法总结:
插入算法的核心是 每次循环到一个数时,都认为这个数之前的数列都是排好序的,将一个数插入到已经排好序的有序数列中,从而得到一个新的、个数加一的有序数列。
过程:从第一个元素开始,第一个数肯定是有序的,把第二个数和第一个数相比,插入到合适的位置,这样前两个数就是有序的了,接着,把第三个元素插入到前面包含两个元素的有序列表中,依次类推,知道插完第n个数据。
第一步:拿一个有序数列为基础,后边加一个数,实现插入排序的逻辑
a=[3,5,8,10,6]
代码
#encodjng=utf-8
a=[3,5,8,10,6]
print a
index=len(a)-1
for j in range(index-1,-1,-1):
print "j:",j
if a[j+1] < a[j]:
a[j+1],a[j]=a[j],a[j+1]
print "a[j+1] < a[j]:","%s < %s"%(a[j+1],a[j])
print " a:",a
else:
break
print a
执行过程:
D:\test>python test.py
[3, 5, 8, 10, 6]
j: 3
a[j+1] < a[j]: 10 < 6
a: [3, 5, 8, 6, 10]
j: 2
a[j+1] < a[j]: 8 < 6
a: [3, 5, 6, 8, 10]
j: 1
[3, 5, 6, 8, 10]
可以看到,默认列表前4个数3,5,8,10是从小到大排好序的,然后j从10的坐标3向前遍历到3的坐标1;
当j为3时,用j坐标后边的值(6)和j坐标的值做对比,如果6小(j[j+1] < a[j]),把6和j坐标的值交换;
当j为2时,用j坐标后边的值(还是6,因为6已经换到这儿了),如果6小(j[j+1] < a[j]),把6和j坐标的值交换;
以此类推,就间接的实现了程序的逻辑:用新的数从后往前依次和前面的排好序的数列对比,小于的话就放到前边,类似冒泡排序的反过程,之所以说是间接,是因为对比的过程并不是用新的数6和依次和前边的数做对比,而是用a[j+1]和a[j]这种取坐标的方式作对比,只不过这种下标的方式取得结果看上去是用6和前面的数依次做对比。所以,同一种算法思路可能会有多种实现方式,这里,也可以用临时变量的形式实现直观的用6和前边的数作对比,以后尝试实现。
第二步:将列表的所有元素按照步骤一的逻辑实现
代码:
#encodjng=utf-8
a=[9,2,5,1,0,4]
print a
index=len(a)-1
for i in range(index):
print "i:",i
for j in range(i,-1,-1):
print "j:",j
if a[j+1] < a[j]:
a[j+1],a[j]=a[j],a[j+1]
print "a[j+1] < a[j]:","%s < %s"%(a[j+1],a[j])
print " a:",a
else:
break
print a
执行过程:
D:\test>python test.py
[9, 2, 5, 1, 0, 4]
i: 0
j: 0
a[j+1] < a[j]: 9 < 2
a: [2, 9, 5, 1, 0, 4]
[2, 9, 5, 1, 0, 4]
i: 1
j: 1
a[j+1] < a[j]: 9 < 5
a: [2, 5, 9, 1, 0, 4]
j: 0
[2, 5, 9, 1, 0, 4]
i: 2
j: 2
a[j+1] < a[j]: 9 < 1
a: [2, 5, 1, 9, 0, 4]
j: 1
a[j+1] < a[j]: 5 < 1
a: [2, 1, 5, 9, 0, 4]
j: 0
a[j+1] < a[j]: 2 < 1
a: [1, 2, 5, 9, 0, 4]
[1, 2, 5, 9, 0, 4]
i: 3
j: 3
a[j+1] < a[j]: 9 < 0
a: [1, 2, 5, 0, 9, 4]
j: 2
a[j+1] < a[j]: 5 < 0
a: [1, 2, 0, 5, 9, 4]
j: 1
a[j+1] < a[j]: 2 < 0
a: [1, 0, 2, 5, 9, 4]
j: 0
a[j+1] < a[j]: 1 < 0
a: [0, 1, 2, 5, 9, 4]
[0, 1, 2, 5, 9, 4]
i: 4
j: 4
a[j+1] < a[j]: 9 < 4
a: [0, 1, 2, 5, 4, 9]
j: 3
a[j+1] < a[j]: 5 < 4
a: [0, 1, 2, 4, 5, 9]
j: 2
[0, 1, 2, 4, 5, 9]可以看到,核心还是第一步实现的逻辑(第二层循环);
当i从第一个数的坐标(0)便利到最后第二个数的坐标(len(a) -1 -1),j就从坐标i往回遍历到坐标0;
然后用j+1坐标的值和前边的j坐标的值作对比,如果小于,就挪到前边,不小于就跳出;
这样插入的逻辑就从第一个数执行到最后一个数,整个排序算法就执行完了
python插入排序算法总结的更多相关文章
- Python—插入排序算法
# 插入排序,时间复杂度O(n²) def insert_sort(arr): """ 插入排序:以朴克牌为例,从小到大排序.摸到的牌current与手里的每张牌进行对比 ...
- python --- 插入排序算法
先上一张图,看看能不能从里面悟出些什么: 问题的解决思路: 就是当插入第i个的时候,前面的[i- 1]个已经排好了,这时候lst[i]就倒过来逐个和前面的关键字顺序进行比较,找到插入位置即将lst[i ...
- 《算法4》2.1 - 插入排序算法(Insertion Sort), Python实现
排序算法列表电梯: 选择排序算法:详见 Selection Sort 插入排序算法(Insertion Sort):非常适用于小数组和部分排序好的数组,是应用比较多的算法.详见本文 插入排序算法的语言 ...
- python实现排序算法(一)——插入排序算法
''' 插入排序算法 原始数据data 排序数据后数据SortedData,默认是从小打大排序 1.从data第一个元素开始,该元素赋值给SortedData[0],可以认为SortedData已经被 ...
- 史上最详细的C语言和Python的插入排序算法
史上最详细的C语言和Python的插入排序算法插入排序原理:所谓插入排序,就像我们在打牌(斗地主)时,整理我们自己手中自己的牌一样,就像是2,1,3,9,J,K,5,4,这四张牌.我们要把它其中的几张 ...
- python算法与数据结构-插入排序算法(34)
一.插入排序的介绍 插入排序的工作方式非常像人们排序一手扑克牌一样.开始时,我们的左手为空并且桌子上的牌面朝下.然后,我们每次从桌子上拿走一张牌并将它插入左手中正确的位置.为了找到一张牌的正确位置,我 ...
- Python 基础算法
递归 时间&空间复杂度 常见列表查找 算法排序 数据结构 递归 在调用一个函数的过程中,直接或间接地调用了函数本身这就叫做递归. 注:python在递归中没用像别的语言对递归进行优化,所以每一 ...
- Python排序算法——希尔排序(Shell’s Sort)
有趣的事,Python永远不会缺席! 如需转发,请注明出处:小婷儿的python https://www.cnblogs.com/xxtalhr/p/10793487.html 一.希尔排序(Shel ...
- python常用算法学习(3)
1,什么是算法的时间和空间复杂度 算法(Algorithm)是指用来操作数据,解决程序问题的一组方法,对于同一个问题,使用不同的算法,也许最终得到的结果是一样的,但是在过程中消耗的资源和时间却会有很大 ...
随机推荐
- nginx虚拟目录配置
参考文章:https://blog.csdn.net/whatday/article/details/50649461 1. location ~ ^/awstats/ { root /home/aw ...
- NodeJS 实现基于 token 的认证应用
此段摘自 http://zhuanlan.zhihu.com/FrontendMagazine/19920223 英文原文 http://code.tutsplus.com/tutorials/tok ...
- you do not have permission to pull from the repository解决方法
使用git进行项目的版本管理,换了台电脑,配置了账号和邮箱后,pull一个私有项目的时候,发现一个问题: 原因分析: 这是由于没有设置Gitee的SSH公钥.在未设置SSH公钥的情况下,可以使用git ...
- Elasticsearch 自定义映射
尽管在很多情况下基本域数据类型 已经够用,但你经常需要为单独域自定义映射 ,特别是字符串域.自定义映射允许你执行下面的操作: 全文字符串域和精确值字符串域的区别 使用特定语言分析器 优化域以适应部分匹 ...
- Centos7.2安装ruby用于爬虫脚本
1,系统版本查看 2,安装依赖包 yum -y install ruby-devel yum -y install mysql-devel yum -y install gcc-c++ gcc r ...
- JS security
下文本文将结合代码向读者展示常见这些 JavaScript 安全漏洞,以便读者在实际编码过程中注意到这些安全问题,及早规避这些风险. 基于 DOM 的跨站点脚本编制 我们都听说过 XSS(Cross ...
- iOS多线程编程之自定义NSOperation(转载)
一.实现一个简单的tableView显示效果 实现效果展示: 代码示例(使用以前在主控制器中进行业务处理的方式) 1.新建一个项目,让控制器继承自UITableViewController. 1 // ...
- 设计模式之——flyweight模式
flyweight模式,又叫做享元模式. 顾名思义,享元模式就是共享一个元素. 百度百科 解释为: 享元模式(英语:Flyweight Pattern)是一种软件设计模式.它使用共享物件,用来尽可能减 ...
- Django - 学习目录
Django 基础 web应用/http协议/web框架 Django简介 Django - 路由层(URLconf) Django - 视图层 Django - 模板层 Django - 模型层 - ...
- 懂点PS技巧,你会减少很多痛苦
UI设计 不像平面设计那样随性, 期间可以用点技巧来减少痛苦. 1. 设置网格线 保持像素完美 不在1:1分辨率下也能保持像素完美,可以通过创建网格线来避免虚边的出现. 编辑 > 首选项 > ...