python快速排序的实现及运行时间比较


Posted in Python onNovember 22, 2019

快速排序的基本思想:首先选定一个数组中的一个初始值,将数组中比该值小的放在左边,比该值大的放在右边,然后分别对左边的数组进行如上的操作,对右边的数组进行如上的操作。(分治+递归)

1.利用匿名函数lambda

匿名函数的基本用法func_name  = lambda x:array,冒号左边的x代表传入的参数,冒号右边的array代表返回值,当然名字是可以自己取的。

quick_sort = lambda array: \
  array if len(array) <= 1 \
    else quick_sort([item for item in array[1:] if item <= array[0]]) \
       + [array[0]] + \
       quick_sort([item for item in array[1:] if item > array[0]])

2.将匿名函数拆解封装为函数

def func2(array):
  if len(array)<=1:
    return array
  tmp = array[0]
  left = [x for x in array[1:] if x<=tmp]
  right = [x for x in array[1:] if x>tmp]
  return func2(left) + [tmp] + func2(right)

3.网上常见的

def func2(array,left,right):
  if left>=right:
    return
  low=left
  high=right
  tmp=array[low]
  while left<right:
    while left<right and array[right]>tmp:
      right-=1
    array[left] = array[right]
    while left<right and array[left]<=tmp:
      left+=1
    array[right]=array[left]
  array[right]=tmp
  func2(array,low,left-1)
  func2(array,left+1,high)

4.算法导论里面的

def func3(array, l, r):
  if l < r:
    q = partition(array, l, r)
    func3(array, l, q - 1)
    func3(array, q + 1, r)
def partition(array, l, r):
  x = array[r]
  i = l - 1
  for j in range(l, r):
    if array[j] <= x:
      i += 1
      array[i], array[j] = array[j], array[i]
  array[i + 1], array[r] = array[r], array[i + 1]
  return i + 1

5.利用栈实现非递归版本

def func4(array, l, r):
  if l >= r:
    return
  stack = []
  stack.append(l)
  stack.append(r)
  while stack:
    low = stack.pop(0)
    high = stack.pop(0)
    if high - low <= 0:
      continue
    x = array[high]
    i = low - 1
    for j in range(low, high):
      if array[j] <= x:
        i += 1
        array[i], array[j] = array[j], array[i]
    array[i + 1], array[high] = array[high], array[i + 1]
    stack.extend([low, i, i + 2, high])

6.python内置的

sorted(array)

本来是想利用装饰器来测一下每个函数的运行时间的,但是由于快排里面存在递归,使用装饰器会报错,就只好一个个计算了。这里还是贴一下用装饰器计算时间的代码:

def count_time(func):
  @wraps(func)
  def helper(func,*args,**kwargs):
    start=time()
    result = func(*args,**kwargs)
    end=time()
    print("函数:", func.__name__, "运行时间:", round(end - start, 4), "s")
    return result
  return helper

这里我们的输入是随机生成的在0-100间的整数,我们测试一下在不同数量下的消耗时间:

from functools import wraps
from random import randint
from time import time
func1_start =time()
res = quick_sort(array)
func1_end =time()
print("函数:func1 运行时间:", round(func1_end - func1_start, 4), "s")
func2_start =time()
func2(array)
func2_end =time()
print("函数:func2 运行时间:", round(func2_end - func2_start, 4), "s")
func3_start =time()
func3(array,0,len(array)-1)
func3_end =time()
print("函数:func3 运行时间:", round(func3_end - func3_start, 4), "s")
func4_start =time()
func4(array,0,len(array)-1)
func4_end =time()
print("函数:func4 运行时间:", round(func4_end - func4_start, 4), "s")
func5_start =time()
func5(array,0,len(array)-1)
func5_end =time()
print("函数:func5 运行时间:", round(func5_end - func5_start, 4), "s")
func6_start =time()
sorted(array)
func6_end =time()
print("函数:func6 运行时间:", round(func6_end - func6_start, 4), "s")

输入array的定义:

array = [randint(0,100) for i in range(5000)]

需要注意的是,随着数据量的增加,方法4,也就是算法导论中的会出现以下问题:

python快速排序的实现及运行时间比较

 这是因为python中的递归深度是有一定限制的,可以使用如下方法暂时解决该问题:

import sys
sys.setrecursionlimit(100000)

同时,方法4还会出现内存溢出问题,方法4也太坑了。

python快速排序的实现及运行时间比较

 最后对比一下这些方法消耗的时间:

python快速排序的实现及运行时间比较

 总结:

方法一、方法二速度较快,同时也较好理解,想要学会快速排序,只要记住方法二即可;

python内置的排序速度还是最快的呀;

以上所述是小编给大家介绍的python快速排序的实现及运行时间比较,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Python 相关文章推荐
Python中的map()函数和reduce()函数的用法
Apr 27 Python
深入解析Python中的集合类型操作符
Aug 19 Python
python从入门到精通(DAY 1)
Dec 20 Python
理解Python中的With语句
Mar 18 Python
Python的Flask框架中的Jinja2模板引擎学习教程
Jun 30 Python
python 打印出所有的对象/模块的属性(实例代码)
Sep 11 Python
Python爬虫实战:分析《战狼2》豆瓣影评
Mar 26 Python
Python文件操作中进行字符串替换的方法(保存到新文件/当前文件)
Jun 28 Python
python基于socket实现的UDP及TCP通讯功能示例
Nov 01 Python
Python类的动态绑定实现原理
Mar 21 Python
使用pyecharts1.7进行简单的可视化大全
May 17 Python
使用python求斐波那契数列中第n个数的值示例代码
Jul 26 Python
Python实现平行坐标图的绘制(plotly)方式
Nov 22 #Python
Python Celery多队列配置代码实例
Nov 22 #Python
python 协程 gevent原理与用法分析
Nov 22 #Python
python 并发下载器实现方法示例
Nov 22 #Python
使用python绘制二维图形示例
Nov 22 #Python
python将邻接矩阵输出成图的实现
Nov 21 #Python
python实现小世界网络生成
Nov 21 #Python
You might like
Thinkphp模板中截取字符串函数简介
2014/06/17 PHP
PHP+iFrame实现页面无需刷新的异步文件上传
2014/09/16 PHP
PHP简单选择排序算法实例
2015/01/26 PHP
如何通过Linux命令行使用和运行PHP脚本
2015/07/29 PHP
PHP的Laravel框架中使用AdminLTE模板来编写网站后台界面
2016/03/21 PHP
PHP Web表单生成器案例分析
2020/06/02 PHP
Js 本页面传值实现代码
2009/05/17 Javascript
extjs 学习笔记(三) 最基本的grid
2009/10/15 Javascript
JQuery中form验证出错信息的查看方法
2013/10/08 Javascript
推荐一个自己用的封装好的javascript插件
2015/01/29 Javascript
解决wx.onMenuShareTimeline出现的问题
2016/08/16 Javascript
js模糊查询实例分享
2016/12/26 Javascript
浅谈ajax在jquery中的请求和servlet中的响应
2018/01/22 jQuery
Vue中使用canvas方法总结
2019/02/12 Javascript
简单了解three.js 着色器材质
2020/08/03 Javascript
用Python实现最速下降法求极值的方法
2019/07/10 Python
CSS3 优势以及网页设计师如何使用CSS3技术
2009/07/29 HTML / CSS
前端canvas水印快速制作(附完整代码)
2019/09/19 HTML / CSS
HTML5自定义元素播放焦点图动画的实现
2019/09/25 HTML / CSS
露营世界:Camping World
2017/02/02 全球购物
德国Discount-Apotheke中文官网:DC德式康线上药房
2020/02/18 全球购物
介绍一下javax.servlet.Servlet接口及其主要方法
2015/11/30 面试题
厨师长岗位职责
2014/03/02 职场文书
环保建议书200字
2014/05/14 职场文书
营销团队口号
2014/06/06 职场文书
农林经济管理专业自荐信
2014/09/01 职场文书
党员个人年度总结
2015/02/14 职场文书
报案材料怎么写
2015/05/25 职场文书
2015年店长个人工作总结
2015/10/23 职场文书
初任公务员培训心得体会
2016/01/08 职场文书
司法廉洁教育心得体会
2016/01/20 职场文书
python中pandas.read_csv()函数的深入讲解
2021/03/29 Python
python中sys模块的介绍与实例
2021/04/17 Python
Python OpenCV实现传统图片格式与base64转换
2021/06/13 Python
golang定时器
2022/04/14 Golang
MySQL数据库查询之多表查询总结
2022/08/05 MySQL