位置: 编程技术 - 正文
推荐整理分享浅谈插入排序算法在Python程序中的实现及简单改进,希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!
Python实现插入排序的一般范例为:
插入算法的原理是:当前元素和已经排序好的部分比较,满足条件时插入,插入点之后的元素全部往后移。然而,我也正是受这个描述的误导,在实现的时候走了一些弯路。比如有以下列表:
比如当前元素是,我在开最初的实现思路是从列表的第一个元素开始,一直比较到元素才找到合适位置.这样做最终是可以实现排序的,但是有一个问题,就是当我把插入的位置之后,和都需要往后移,这又需要另一个循环,实现如下:
首先,引入了三个循环变量以及三层循环,效率较低;其次是代码结构会比较混乱,需要改进。
后来我想能不能比较完一个元素就把它移到合适的位置,好如去超市买水果,手里拿到不合适的,总会直接把它放到一边,不会再碰它。具体到算法实现,还用上面的列表举例,当前元素是,先跟相邻的比较,发现比大,则往后移动一位,即移到所在位置;然后和比较,又会把往后移动一位;在比较到元素5时,发现已经找到了应该存放的位置,而此时移动也随之完成。代码实现如下:
孰优孰劣,大家对比便知。
图文讲解选择排序算法的原理及在Python中的实现 基本思想:从未排序的序列中找到一个最小的元素,放到第一位,再从剩余未排序的序列中找到最小的元素,放到第二位,依此类推,直到所有元素都
Python手机号码归属地查询代码 简单的一个例子,是以前用Dephi写的,前不久刚实现了一个在Python中使用Delphi控件来编写界面程序,于是趁热写一个类似的的查询方案。本实例是通过www
Python编程中归并排序算法的实现步骤详解 基本思想:归并排序是一种典型的分治思想,把一个无序列表一分为二,对每个子序列再一分为二,继续下去,直到无法再进行划分为止。然后,就开
标签: 浅谈插入排序算法在Python程序中的实现及简单改进
本文链接地址:https://www.jiuchutong.com/biancheng/386141.html 转载请保留说明!友情链接: 武汉网站建设