Python实现快速排序和插入排序算法及自定义排序的示例


Posted in Python onFebruary 16, 2016

一、快速排序

    快速排序(Quicksort)是对冒泡排序的一种改进。由C. A. R. Hoare在1962年提出。它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。

    快速排序,递归实现

def quick_sort(num_list):
  """
  快速排序
  """
  if num_list == []:
    return num_list
  smallList = []
  bigList = []
  middleElement = num_list[0]
  for i in num_list[1:]:
    if i <= middleElement:
      smallList.append(i)
    else:
      bigList.append(i)
  return quick_sort(smallList)+[middleElement]+quick_sort(bigList)

二、插入排序

    插入排序(Insertion Sort)的算法描述是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place排序(即只需用到O(1)的额外空间的排序),因而在从后向前扫描过程中,需要反复把已排序元素逐步向后挪位,为最新元素提供插入空间。

    插入排序

def insert_sort(num_list):
  """
  插入排序
  """
  for i in range(len(num_list)-1):
    for j in range(i+1, len(num_list)):
      if num_list[i]>num_list[j]:
        num_list[i],num_list[j] = num_list[j],num_list[i]
  return num_list


三、自定义排序
利用 sort() 或 sorted() 的 key 即可实现。

    示例如下:

def sort_key(obj):
  sorted_list = [4, 2, 5, 9, 7, 8, 1, 3, 6, 0]
  return sorted_list.index(obj)
 
 
if __name__ == '__main__':
  print sorted(range(10), key=sort_key)
 
# 输出结果如下
[4, 2, 5, 9, 7, 8, 1, 3, 6, 0]

 
# 利用关键字在列表中的索引位置,进行自定义排序

Python 相关文章推荐
Python中的类与对象之描述符详解
Mar 27 Python
在Python中使用swapCase()方法转换大小写的教程
May 20 Python
举例讲解Python面相对象编程中对象的属性与类的方法
Jan 19 Python
python使用PIL模块获取图片像素点的方法
Jan 08 Python
python 实现selenium断言和验证的方法
Feb 13 Python
python实现全盘扫描搜索功能的方法
Feb 14 Python
django配置连接数据库及原生sql语句的使用方法
Mar 03 Python
Django实现web端tailf日志文件功能及实例详解
Jul 28 Python
解析pip安装第三方库但PyCharm中却无法识别的问题及PyCharm安装第三方库的方法教程
Mar 10 Python
解决PyCharm不在run输出运行结果而不是再Console里输出的问题
Sep 21 Python
python操作ini类型配置文件的实例教程
Oct 30 Python
如何一键升级Python所有包
Nov 05 Python
python实现红包裂变算法
Feb 16 #Python
轻松实现python搭建微信公众平台
Feb 16 #Python
十条建议帮你提高Python编程效率
Feb 16 #Python
bpython 功能强大的Python shell
Feb 16 #Python
深入解读Python解析XML的几种方式
Feb 16 #Python
Python3.2模拟实现webqq登录
Feb 15 #Python
python编码最佳实践之总结
Feb 14 #Python
You might like
怎样在UNIX系统下安装php3
2006/10/09 PHP
PHP ajax 分页类代码
2008/11/13 PHP
php echo()和print()、require()和include()函数区别说明
2010/03/27 PHP
PHP下利用shell后台运行PHP脚本,并获取该脚本的Process ID的代码
2011/09/19 PHP
php将文件夹打包成zip文件的简单实现方法
2016/10/04 PHP
PHP单例模式简单用法示例
2017/06/23 PHP
PHP使用反向Ajax技术实现在线客服系统详解
2019/07/01 PHP
javascript 数组学习资料收集
2010/04/11 Javascript
jQuery $.data()方法使用注意细节
2012/12/31 Javascript
jquery 文本上下无缝滚动,鼠标放上去就停止 小例子
2013/06/05 Javascript
JS鼠标滑过图片时切换图片实现思路
2013/09/12 Javascript
如何将php数组或者对象传递给javascript
2014/03/20 Javascript
使用JavaScript获取电池状态的方法
2014/05/03 Javascript
JavaScript数组常用方法
2015/03/02 Javascript
easyui datebox 时间限制,datebox开始时间限制结束时间,datebox截止日期比起始日期大的实现代码
2017/01/12 Javascript
vue 获取到数据但却渲染不到页面上的解决方法
2020/11/19 Vue.js
使用jquery实现轮播图效果
2021/01/02 jQuery
python学习笔记之调用eval函数出现invalid syntax错误问题
2015/10/18 Python
一些常用的Python爬虫技巧汇总
2016/09/28 Python
在Python中使用AOP实现Redis缓存示例
2017/07/11 Python
python numpy和list查询其中某个数的个数及定位方法
2018/06/27 Python
Python面向对象之类和对象属性的增删改查操作示例
2018/12/14 Python
Python包,__init__.py功能与用法分析
2020/01/07 Python
Django ORM 查询表中某列字段值的方法
2020/04/30 Python
python 基于selectors库实现文件上传与下载
2020/12/31 Python
香港礼品网站:GiftU eshop
2017/09/01 全球购物
MAC彩妆英国官网:M·A·C UK
2018/05/30 全球购物
幼儿园中班开学寄语
2014/04/03 职场文书
2014年五四青年节演讲比赛方案
2014/04/22 职场文书
敲诈同学钱财检讨书范文
2014/11/18 职场文书
公司股份合作协议书
2014/12/07 职场文书
2015年志愿者服务工作总结
2015/04/20 职场文书
幼儿园园长新年寄语
2015/08/17 职场文书
mysql批量新增和存储的方法实例
2021/04/07 MySQL
Mysql基础之常见函数
2021/04/22 MySQL
MySQL 自动填充 create_time 和 update_time
2022/05/20 MySQL