浅谈插入排序算法在Python程序中的实现及简单改进


Posted in Python onMay 04, 2016

Python实现插入排序的一般范例为:

#coding=cp936
#coding=cp936
#插入排序算法
def InsertionSort(A):
  for j in range(1,len(A)):
    key = A[j]
    i = j-1
    #向前查找插入位置
    while i>=0 and A[i]>key:
      A[i+1] = A[i]
      i = i-1
    A[i+1] = key
 
#初始化输入数据
A = []
input = raw_input('please input some numbers:') #输入逗号分隔整数列 如:7,6,5,1,8,34
for item in input.split(','):
  A.append(int(item))
 
InsertionSort(A)#插入排序
print A

插入算法的原理是:当前元素和已经排序好的部分比较,满足条件时插入,插入点之后的元素全部往后移。
然而,我也正是受这个描述的误导,在实现的时候走了一些弯路。比如有以下列表:

test = [2, 5, 11, 21, 10, 18, 24]

比如当前元素是10,我在开最初的实现思路是从列表的第一个元素开始,一直比较到元素11才找到合适位置.这样做最终是可以实现排序的,但是有一个问题,就是当我把10插入11的位置之后,11和21都需要往后移,这又需要另一个循环,实现如下:

def insertSort(sort_list):
  list_length = len(sort_list)
  if list_length < 2 :
    return sort_list
  for i in range(1,list_length):
    key = sort_list[i]
    j = 0
    while j < i:
      if sort_list[j] > key:
        for k in range(i,j,-1):
          sort_list[k] = sort_list[k-1]
        sort_list[j] = key
        break
      j += 1
  return sort_list

   首先,引入了三个循环变量以及三层循环,效率较低;其次是代码结构会比较混乱,需要改进。

后来我想能不能比较完一个元素就把它移到合适的位置,好如去超市买水果,手里拿到不合适的,总会直接把它放到一边,不会再碰它。具体到算法实现,还用上面的列表举例,当前元素是10,先跟相邻的21比较,发现21比10大,则21往后移动一位,即移到10所在位置;然后10和11比较,又会把11往后移动一位;在比较到元素5时,发现已经找到了10应该存放的位置,而此时移动也随之完成。
代码实现如下:

def insertSort(sort_list):
  list_length = len(sort_list)
  if list_length < 2 :
    return sort_list
  for i in range(1,list_length):
    key = sort_list[i]
    j = i - 1
    while j >=0 and sort_list[j] > key:
      sort_list[j+1] = sort_list[j]
      j -= 1
    sort_list[j+1] = key
  return sort_list

   孰优孰劣,大家对比便知。

Python 相关文章推荐
Python类定义和类继承详解
May 08 Python
Python3读取文件常用方法实例分析
May 22 Python
详解Python操作RabbitMQ服务器消息队列的远程结果返回
Jun 30 Python
Python爬虫框架scrapy实现downloader_middleware设置proxy代理功能示例
Aug 04 Python
解决Django一个表单对应多个按钮的问题
Jul 18 Python
基于Python检测动态物体颜色过程解析
Dec 04 Python
Python 寻找局部最高点的实现
Dec 05 Python
如何将 awk 脚本移植到 Python
Dec 09 Python
Python+PyQt5实现灭霸响指功能
May 25 Python
python3通过subprocess模块调用脚本并和脚本交互的操作
Dec 05 Python
PyCharm 光标变成黑块的解决方式
Feb 06 Python
浅析python中特殊文件和特殊函数
Feb 24 Python
Python中使用插入排序算法的简单分析与代码示例
May 04 #Python
Python中函数参数设置及使用的学习笔记
May 03 #Python
解析Mac OS下部署Pyhton的Django框架项目的过程
May 03 #Python
Python使用urllib2模块抓取HTML页面资源的实例分享
May 03 #Python
Python中字符串的格式化方法小结
May 03 #Python
Python实现约瑟夫环问题的方法
May 03 #Python
Python实现堆排序的方法详解
May 03 #Python
You might like
PHP获取和操作配置文件php.ini的几个函数介绍
2013/06/24 PHP
Zend studio文件注释模板设置方法
2013/09/29 PHP
在 Laravel 中 “规范” 的开发短信验证码发送功能
2017/10/26 PHP
Laravel Eloquent分表方法并使用模型关联的实现
2019/11/25 PHP
jquery实现手机号码选号的方法
2015/07/31 Javascript
jQuery自定义数值抽奖活动代码
2016/06/11 Javascript
详解Angular2响应式表单
2017/06/14 Javascript
JS 验证密码 不能为空,必须含有数字、字母、特殊字符,长度在8-12位
2017/06/21 Javascript
[原创]jquery判断元素内容是否为空的方法
2018/05/04 jQuery
vue+axios新手实践实现登陆的示例代码
2018/06/06 Javascript
vue 自定义提示框(Toast)组件的实现代码
2018/08/17 Javascript
NodeJS加密解密及node-rsa加密解密用法详解
2018/10/12 NodeJs
Node.js Event Loop各阶段讲解
2019/03/08 Javascript
微信小程序收货地址API兼容低版本解决方法
2019/05/18 Javascript
layer iframe 设置关闭按钮的方法
2019/09/12 Javascript
vue路由切换时取消之前的所有请求操作
2020/09/01 Javascript
[59:36]2018DOTA2亚洲邀请赛 4.3 突围赛 Secret vs VG 第二场
2018/04/04 DOTA
Mac OS X10.9安装的Python2.7升级Python3.3步骤详解
2013/12/04 Python
pandas string转dataframe的方法
2018/04/11 Python
Python实现的拟合二元一次函数功能示例【基于scipy模块】
2018/05/15 Python
python调用Matplotlib绘制分布点并且添加标签
2018/05/31 Python
Python 删除连续出现的指定字符的实例
2018/06/29 Python
Python中fnmatch模块的使用详情
2018/11/30 Python
对python 自定义协议的方法详解
2019/02/13 Python
python 多个参数不为空校验方法
2019/02/14 Python
python os.fork() 循环输出方法
2019/08/08 Python
解决TensorFlow GPU版出现OOM错误的问题
2020/02/03 Python
加拿大时尚床上用品零售商:QE Home | Quilts Etc
2018/01/22 全球购物
卫校护理专业毕业生求职信
2013/11/26 职场文书
旅游市场营销方案
2014/03/09 职场文书
调查研究项目计划书
2014/04/29 职场文书
单位法人授权委托书范本
2014/10/09 职场文书
泸县召开党的群众路线教育实践活动总结大会新闻稿
2014/10/21 职场文书
实训报告范文大全
2014/11/04 职场文书
寒山寺导游词
2015/02/03 职场文书
教师考核表个人总结
2015/02/12 职场文书