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在人工智能中的作用
Nov 14 Python
python实现关键词提取的示例讲解
Apr 28 Python
[原创]Python入门教程2. 字符串基本操作【运算、格式化输出、常用函数】
Oct 29 Python
在pycharm中设置显示行数的方法
Jan 16 Python
关于Pytorch的MNIST数据集的预处理详解
Jan 10 Python
Python中使用socks5设置全局代理的方法示例
Apr 15 Python
Python函数参数定义及传递方式解析
Jun 10 Python
python音频处理的示例详解
Dec 23 Python
python 制作网站筛选工具(附源码)
Jan 21 Python
Python实现byte转integer
Jun 03 Python
Python还能这么玩之只用30行代码从excel提取个人值班表
Jun 05 Python
Python+Pillow+Pytesseract实现验证码识别
May 11 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文件下载类
2006/12/06 PHP
php基础教程 php内置函数实例教程
2012/08/21 PHP
smarty中常用方法实例总结
2015/08/07 PHP
php+flash+jQuery多图片上传源码分享
2020/07/27 PHP
PHP的mysqli_ssl_set()函数讲解
2019/01/23 PHP
浅谈laravel orm 中的一对多关系 hasMany
2019/10/21 PHP
PHP判断当前使用的是什么浏览器(推荐)
2019/10/27 PHP
jQuery教程 $()包装函数来实现数组元素分页效果
2013/08/13 Javascript
判断JS对象是否拥有某种属性的两种方式
2013/12/02 Javascript
动态的绑定事件addEventListener方法的使用
2014/01/24 Javascript
jquery隔行换色效果实现方法
2015/01/15 Javascript
jQuery实现延迟跳转的方法
2015/06/05 Javascript
深入理解Vue官方文档梳理之全局API
2017/11/22 Javascript
js实现手机web图片左右滑动效果
2017/12/29 Javascript
Vue3.0结合bootstrap创建多页面应用
2019/05/28 Javascript
阿望教你用vue写扫雷小游戏
2020/01/20 Javascript
使用nodeJS中的fs模块对文件及目录进行读写,删除,追加,等操作详解
2020/02/06 NodeJs
Python网络爬虫与信息提取(实例讲解)
2017/08/29 Python
python3爬虫之设计签名小程序
2018/06/19 Python
Python数据持久化shelve模块用法分析
2018/06/29 Python
提升Python程序性能的7个习惯
2019/04/14 Python
Python实现Selenium自动化Page模式
2019/07/14 Python
python 字符串的驻留机制及优缺点
2020/06/19 Python
python自动化测试三部曲之unittest框架的实现
2020/10/07 Python
一款纯css3实现的鼠标悬停动画按钮
2014/12/29 HTML / CSS
HTML5实现移动端点击翻牌功能
2020/10/23 HTML / CSS
LA MER海蓝之谜美国官网:传奇面霜
2016/08/27 全球购物
出国考察邀请函
2014/01/21 职场文书
物控部经理职务说明书
2014/02/25 职场文书
2015年学校德育工作总结
2015/04/22 职场文书
2015年禁毒工作总结
2015/04/30 职场文书
2015年公司后勤管理工作总结
2015/05/13 职场文书
2015秋季幼儿园开学通知
2015/07/16 职场文书
jquery插件实现代码雨特效
2021/04/24 jQuery
Python还能这么玩之用Python做个小游戏的外挂
2021/06/04 Python
实例详解Python的进程,线程和协程
2022/03/13 Python