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写的Discuz7.2版faq.php注入漏洞工具
Aug 06 Python
浅谈Matplotlib简介和pyplot的简单使用——文本标注和箭头
Jan 09 Python
Python实现PS滤镜Fish lens图像扭曲效果示例
Jan 29 Python
python opencv实现切变换 不裁减图片
Jul 26 Python
Python数据抓取爬虫代理防封IP方法
Dec 23 Python
Python将json文件写入ES数据库的方法
Apr 10 Python
python使用原始套接字发送二层包(链路层帧)的方法
Jul 22 Python
基于Django静态资源部署404的解决方法
Jul 28 Python
简单易懂Pytorch实战实例VGG深度网络
Aug 27 Python
Python爬虫小例子——爬取51job发布的工作职位
Jul 10 Python
python 爬虫爬取京东ps4售卖情况
Dec 18 Python
Python提取PDF指定内容并生成新文件
Jun 09 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/10/09 PHP
新手配置 PHP 调试环境(IIS+PHP+MYSQL)
2007/01/10 PHP
discuz图片顺序混乱解决方案
2015/07/29 PHP
php-fpm开启状态统计的方法详解
2017/06/23 PHP
PHP文件管理之实现网盘及压缩包的功能操作
2017/09/20 PHP
php7性能提升的原因详解
2019/10/13 PHP
laravel框架实现后台登录、退出功能示例
2019/10/31 PHP
限制文本框输入N个字符的js代码
2010/05/13 Javascript
JQuery动态给table添加、删除行 改进版
2011/01/19 Javascript
jquery按回车提交数据的代码示例
2013/11/05 Javascript
Jqgrid表格随窗口大小改变而改变的简单实例
2013/12/28 Javascript
JavaScript实现更改网页背景与字体颜色的方法
2015/02/02 Javascript
JavaScript使用push方法添加一个元素到数组末尾用法实例
2015/04/06 Javascript
js中常用的Math方法总结
2017/01/12 Javascript
超简单的Vue.js环境搭建教程
2017/03/17 Javascript
JS基于设计模式中的单例模式(Singleton)实现封装对数据增删改查功能
2018/02/06 Javascript
vue-router 源码之实现一个简单的 vue-router
2018/07/02 Javascript
js实现图片局部放大效果详解
2019/03/18 Javascript
详解Vue中使用Axios拦截器
2019/04/22 Javascript
[40:48]DOTA2上海特级锦标赛D组败者赛 Liquid VS COL第二局
2016/02/28 DOTA
Python实现SSH远程登陆,并执行命令的方法(分享)
2017/05/08 Python
python爬虫之BeautifulSoup 使用select方法详解
2017/10/23 Python
Pyspider中给爬虫伪造随机请求头的实例
2018/05/07 Python
python实现Zabbix-API监控
2018/09/17 Python
解决安装python库时windows error5 报错的问题
2018/10/21 Python
Python爬虫实现使用beautifulSoup4爬取名言网功能案例
2019/09/15 Python
wxPython色环电阻计算器
2019/11/18 Python
Python实现一个论文下载器的过程
2021/01/18 Python
戴尔美国官网:Dell
2016/08/31 全球购物
爱游人:Travelliker
2017/09/05 全球购物
阿迪达斯越南官网:adidas越南
2020/07/19 全球购物
校本教研工作制度
2014/01/22 职场文书
爱心活动计划书
2014/04/26 职场文书
小学感恩节活动总结
2015/03/24 职场文书
在Django中使用MQTT的方法
2021/05/10 Python
SQL Server携程核心系统无感迁移到MySQL实战
2022/06/01 SQL Server