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制作简单的朴素基数估计器的教程
Apr 01 Python
Python实现提取文章摘要的方法
Apr 21 Python
Python中使用装饰器来优化尾递归的示例
Jun 18 Python
Python利用matplotlib生成图片背景及图例透明的效果
Apr 27 Python
Pycharm学习教程(5) Python快捷键相关设置
May 03 Python
Python绘制的二项分布概率图示例
Aug 22 Python
python安装本地whl的实例步骤
Oct 12 Python
解析Python3中的Import
Oct 13 Python
使用Python脚本从文件读取数据代码实例
Jan 19 Python
使用Tkinter制作信息提示框
Feb 18 Python
Python如何避免文件同名产生覆盖
Jun 09 Python
pycharm实现猜数游戏
Dec 07 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中apc缓存使用示例
2013/12/25 PHP
简单谈谈php浮点数精确运算
2016/03/10 PHP
PHP基于phpqrcode类生成二维码的方法详解
2018/03/14 PHP
详解PHP队列的实现
2019/03/14 PHP
tp5框架使用cookie加密算法实现登录功能示例
2020/02/10 PHP
Javascript 去除数组的重复元素
2010/05/04 Javascript
javascript弹出层输入框(示例代码)
2013/12/11 Javascript
用jquery实现的一个超级简单的下拉菜单
2014/05/18 Javascript
JavaScript监听和禁用浏览器回车事件实例
2015/01/31 Javascript
jQuery基于toggle实现click触发DIV的显示与隐藏问题分析
2016/06/12 Javascript
AngularJS 入门教程之HTML DOM实例详解
2016/07/28 Javascript
微信小程序 选项卡的简单实例
2017/05/24 Javascript
详解vue mint-ui源码解析之loadmore组件
2017/10/11 Javascript
vue 内置过滤器的使用总结(附加自定义过滤器)
2018/12/11 Javascript
Vue实现开心消消乐游戏算法
2019/10/22 Javascript
JS+HTML实现自定义上传图片按钮并显示图片功能的方法分析
2020/02/12 Javascript
vue 动态组件(component :is) 和 dom元素限制(is)用法说明
2020/09/04 Javascript
压缩包密码破解示例分享(类似典破解)
2014/01/17 Python
Python实现快速排序和插入排序算法及自定义排序的示例
2016/02/16 Python
利用python实现命令行有道词典的方法示例
2017/01/31 Python
使用Python通过win32 COM实现Word文档的写入与保存方法
2018/05/08 Python
Python引用计数操作示例
2018/08/23 Python
python利用requests库模拟post请求时json的使用教程
2018/12/07 Python
python utc datetime转换为时间戳的方法
2019/01/15 Python
python数据库编程 ODBC方式实现通讯录
2020/03/27 Python
解决pycharm导入本地py文件时,模块下方出现红色波浪线的问题
2020/06/01 Python
python怎么调用自己的函数
2020/07/01 Python
python实现简单猜单词游戏
2020/12/24 Python
Python读取ini配置文件传参的简单示例
2021/01/05 Python
pycharm 快速解决python代码冲突的问题
2021/01/15 Python
日本乐天官方海外转运服务:Rakuten Global Express
2018/11/30 全球购物
优秀党支部事迹材料
2014/01/14 职场文书
学校运动会广播稿100条
2014/09/14 职场文书
年度考核登记表个人总结
2015/03/06 职场文书
2015年纪检监察工作总结
2015/04/08 职场文书
MySQL触发器的使用
2021/05/24 MySQL