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 数据加密代码
Dec 24 Python
python对DICOM图像的读取方法详解
Jul 17 Python
python实现单向链表详解
Feb 08 Python
python中ASCII码和字符的转换方法
Jul 09 Python
python 使用pandas计算累积求和的方法
Feb 08 Python
python十进制转二进制的详解
Feb 07 Python
tensorflow 利用expand_dims和squeeze扩展和压缩tensor维度方式
Feb 07 Python
python实现udp聊天窗口
Mar 31 Python
详解用Python爬虫获取百度企业信用中企业基本信息
Jul 02 Python
python+selenium实现12306模拟登录的步骤
Jan 21 Python
python反扒机制的5种解决方法
Feb 06 Python
总结Pyinstaller打包的高级用法
Jun 28 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
php实现图片添加水印功能
2014/02/13 PHP
php绘制一条直线的方法
2015/01/24 PHP
PHP中字符安全过滤函数使用小结
2015/02/25 PHP
PHP cURL初始化和执行方法入门级代码
2015/05/28 PHP
php三种实现多线程类似的方法
2015/10/30 PHP
详解PHP对数组的定义以及数组的创建方法
2015/11/27 PHP
PHP 无限级分类
2017/05/04 PHP
小程序微信退款功能实现方法详解【基于thinkPHP】
2019/05/05 PHP
在浏览器中获取当前执行的脚本文件名的代码
2011/07/19 Javascript
Javascript创建自定义对象 创建Object实例添加属性和方法
2012/06/04 Javascript
js实现浏览器的各种菜单命令比如打印、查看源文件等等
2013/10/24 Javascript
js控制多图左右滚动切换效果代码分享
2015/08/26 Javascript
JS获取html元素的标记名实现方法
2016/10/08 Javascript
angular 用拦截器统一处理http请求和响应的方法
2017/06/08 Javascript
Vue.js移动端左滑删除组件的实现代码
2017/09/08 Javascript
node.js使用express框架进行文件上传详解
2019/03/03 Javascript
在Vue项目中使用jsencrypt.js对数据进行加密传输的方法
2019/04/17 Javascript
js实现随机div颜色位置 类似满天星效果
2019/10/24 Javascript
vue-element-admin 菜单标签失效的解决方式
2019/11/12 Javascript
vue项目实现多语言切换的思路
2020/09/17 Javascript
vue实现两个区域滚动条同步滚动
2020/12/13 Vue.js
Python实现建立SSH连接的方法
2015/06/03 Python
Python的Flask框架的简介和安装方法
2015/11/13 Python
python编程实现12306的一个小爬虫实例
2017/12/27 Python
微信小程序跳一跳游戏 python脚本跳一跳刷高分技巧
2018/01/04 Python
python ChainMap 合并字典的实现步骤
2019/06/11 Python
jenkins配置python脚本定时任务过程图解
2019/10/29 Python
使用scrapy ImagesPipeline爬取图片资源的示例代码
2020/09/28 Python
纪伊国屋泰国网上书店:Kinokuniya泰国
2017/12/24 全球购物
软件测试常见笔试题
2012/02/04 面试题
店长岗位的工作内容
2013/11/12 职场文书
中专生职业生涯规划书范文
2014/01/10 职场文书
产品发布会策划方案
2014/05/12 职场文书
实习单位意见
2015/06/04 职场文书
运动会加油稿30字
2015/07/21 职场文书
Golang 实现WebSockets
2022/04/24 Golang