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之编写类之三子类
Oct 11 Python
python实现计算倒数的方法
Jul 11 Python
在Django的视图中使用数据库查询的方法
Jul 16 Python
Python中如何获取类属性的列表
Dec 26 Python
matplotlib绘制符合论文要求的图片实例(必看篇)
Jun 02 Python
Python实现删除文件中含“指定内容”的行示例
Jun 09 Python
Django项目中用JS实现加载子页面并传值的方法
May 28 Python
python查看模块安装位置的方法
Oct 16 Python
Django media static外部访问Django中的图片设置教程
Apr 07 Python
Python操作MySQL数据库的示例代码
Jul 13 Python
Python如何利用Har文件进行遍历指定字典替换提交的数据详解
Nov 05 Python
python 如何用urllib与服务端交互(发送和接收数据)
Mar 04 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
php读取excel文件的简单实例
2013/08/26 PHP
Laravel 5框架学习之Laravel入门和新建项目
2015/04/07 PHP
php版交通银行网银支付接口开发入门教程
2016/09/26 PHP
php表单处理操作
2017/11/16 PHP
javascript 静态对象和构造函数的使用和公私问题
2010/03/02 Javascript
Jquery 动态添加按钮实现代码
2010/05/06 Javascript
Jquery下判断Id是否存在的代码
2011/01/06 Javascript
目前流行的JavaScript库的介绍及对比
2013/09/29 Javascript
在子窗口中关闭父窗口的一句代码
2013/10/21 Javascript
node.js中的fs.lchown方法使用说明
2014/12/16 Javascript
JavaScript中的函数嵌套使用
2015/06/04 Javascript
jQuery插件datatables使用教程
2016/04/21 Javascript
Node.js实现兼容IE789的文件上传进度条
2016/09/02 Javascript
jQuery删除节点用法示例(remove方法)
2016/09/08 Javascript
vue2.0开发实践总结之疑难篇
2016/12/07 Javascript
微信小程序 地图map详解及简单实例
2017/01/10 Javascript
jquery封装插件时匿名函数形参和实参的写法解释
2017/02/14 Javascript
详解jquery选择器的原理
2017/08/01 jQuery
vue的过滤器filter实例详解
2018/09/17 Javascript
帮你彻底搞懂JS中的prototype、__proto__与constructor(图解)
2019/08/23 Javascript
vue+element-ui JYAdmin后台管理系统模板解析
2020/07/28 Javascript
基于wxpython实现的windows GUI程序实例
2015/05/30 Python
Python中如何获取类属性的列表
2016/12/26 Python
Django 如何获取前端发送的头文件详解(推荐)
2017/08/15 Python
python实现电脑自动关机
2018/06/20 Python
Python定义函数功能与用法实例详解
2019/04/08 Python
TripAdvisor日本:全球领先的旅游网站
2019/02/14 全球购物
监察局领导班子四风问题整改措施思想汇报
2014/10/05 职场文书
2015年校长新年寄语
2014/12/08 职场文书
精神文明建设先进个人事迹材料
2014/12/24 职场文书
党员考试作弊检讨书1000字
2015/02/16 职场文书
毕业生对母校寄语
2015/02/26 职场文书
上帝也疯狂观后感
2015/06/09 职场文书
七年级数学教学反思
2016/02/17 职场文书
小学教师教学反思
2016/02/24 职场文书
2016年最美孝心少年事迹材料
2016/02/26 职场文书