编程语言
首页 > 编程语言> > python 三行代码实现快速排序

python 三行代码实现快速排序

作者:互联网

主要利用了行数的递归调用和Python的切片特性,解释一下每行代码的含义:

第四行是最关键的,返回三个部分:

  1. 比列表第一个元素小的所有元素列表递归调用
  2. 第一个元素
  3. 比列表第一个元素大的所有元素列表递归调用

递归调用部分,处理过程都是一样的,用列表第一个参数作为中间值,把列表分为两部分

最后两行是测试代码,生成一个无序列表,打印排序结果。

#coding:utf-8
def qsort(L):
    if len(L) <= 1: return L
    return qsort([lt for lt in L[1:] if lt < L[0]]) + L[0:1]+ \
    qsort([ge for ge in L[1:] if ge >= L[0]])

iList = [3,14,2,12,9,33,99,35]

print qsort(iList)

 

标签:调用,utf,递归,python,元素,列表,lt,三行,排序
来源: https://www.cnblogs.com/weiwei-python/p/14793425.html