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快速查找算法应用实例
Sep 26 Python
python 二维数组90度旋转的方法
Jan 28 Python
Python 一键制作微信好友图片墙的方法
May 16 Python
Python中的引用知识点总结
May 20 Python
python实现五子棋人机对战游戏
Mar 25 Python
Python对列表的操作知识点详解
Aug 20 Python
如何更改 pandas dataframe 中两列的位置
Dec 27 Python
pytorch .detach() .detach_() 和 .data用于切断反向传播的实现
Dec 27 Python
运行tensorflow python程序,限制对GPU和CPU的占用操作
Feb 06 Python
Python网页解析器使用实例详解
May 30 Python
Python 实现定积分与二重定积分的操作
May 26 Python
python for循环赋值问题
Jun 03 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+DBM的同学录程序(1)
2006/10/09 PHP
php 过滤器实现代码
2010/08/09 PHP
php使用curl存储cookie的示例
2014/03/31 PHP
PHP框架Swoole定时器Timer特性分析
2014/08/19 PHP
PHP入门教程之上传文件实例详解
2016/09/11 PHP
PHP自定义函数格式化json数据示例
2016/09/14 PHP
php结合md5的加密解密算法实例
2016/09/30 PHP
PHP模版引擎原理、定义与用法实例
2019/03/29 PHP
ThinkPHP3.2.3框架实现执行原生SQL语句的方法示例
2019/04/03 PHP
jQuery实现列表自动循环滚动鼠标悬停时停止滚动
2013/09/06 Javascript
浅析javascript中函数声明和函数表达式的区别
2015/02/15 Javascript
jquery获取节点名称
2015/04/26 Javascript
JS模拟Dialog弹出浮动框效果代码
2015/10/16 Javascript
js小数计算小数点后显示多位小数的实现方法
2016/05/30 Javascript
JavaScript实现前端分页控件
2017/04/19 Javascript
angular内置provider之$compileProvider详解
2017/09/27 Javascript
Mac 安装 nodejs方法(图文详细步骤)
2017/10/30 NodeJs
使用Vue制作图片轮播组件思路详解
2018/03/21 Javascript
JavaScript变量作用域及内存问题实例分析
2019/06/10 Javascript
JS实现放烟花效果
2020/03/10 Javascript
Python实现PS滤镜特效Marble Filter玻璃条纹扭曲效果示例
2018/01/29 Python
Python使用matplotlib和pandas实现的画图操作【经典示例】
2018/06/13 Python
Python装饰器基础概念与用法详解
2018/12/22 Python
在Pycharm中修改文件默认打开方式的方法
2019/01/17 Python
Pytorch加载部分预训练模型的参数实例
2019/08/18 Python
基于python调用psutil模块过程解析
2019/12/20 Python
Juice Beauty官网:有机美容产品,护肤与化妆品
2020/06/13 全球购物
Lancer Skincare官方网站:抗衰老皮肤护理
2020/11/20 全球购物
介绍下Java中==和equals的区别
2013/09/01 面试题
投标人廉洁自律承诺书
2014/05/26 职场文书
励志演讲稿800字
2014/08/21 职场文书
2014年高三班主任工作总结
2014/12/05 职场文书
大学生村官工作总结2015
2015/04/09 职场文书
大学生军训感言
2015/08/01 职场文书
大学生创业计划书
2019/06/24 职场文书
文书工作总结(范文)
2019/07/11 职场文书