快速排序(Python版)--个人理解写到详细注释中

  • 深入理解算法中‘分割’的概念。
  • 在序列变换中巧妙使用‘空位’, 使代码变得美观
  • 推荐每个程序员可以在十分钟内写完如下代码
  • 面试前,先写个快排
  • 在入门一个新的程序语言时,不妨先写个快排练练
# Quick Sort 
# 选取一个Key 
# 对比: 将比Key小的放到左边,比Key大的放到右边
# 循环: 直至每个元素都与key对比过了
# 递归: key左侧的和key右侧的分别递归

list = [5,7,1,8,4]
count = len(list)
def quickSort(L, low, high):
    print('\nquickSort: ', L, low, high)
    i = low 
    j = high
    if i >= j:
        return L
    # 为了序列调位方便 在序列中挖出一个空位
    # 此时空位 序列中i的位置
    key = L[i] 
    while i < j:
        while i < j and L[j] >= key: # 遍历key右侧的值
            j = j-1                  # 若不小于key,j向左挪一个 
        # 此时序列中的空位为L[i],赋值后变为L[j]
        L[i] = L[j]   #此时j指向的值小于key, 将其赋给i指向的位置(i值在key 值的左侧)
        while i < j and L[i] <= key: #遍历key左侧的值
            i = i+1                  # 若不大于key, i 向右挪一个
        # 此时序列中的空位为L[j], 赋值后变为L[i]
        L[j] = L[i]   #此时i 指向的值大于key,将其值赋给(空位)
        print(L, i, j)
        # 每循环一次调整序列中的两个值
        # key右侧的一个值和key左侧的一个值
        # 不断循环直到i = j,即key左侧的均小于key,右侧的均大于key
    # 此时i = j , 将key值放入空位中   
    L[i] = key 
    quickSort(L, low, i-1)
    quickSort(L, j+1, high)
    return L 

quickSort(list,0,count-1)

无注释版

def quick_sort(lists, left, right):
    # 快速排序
    if left >= right:
        return lists
    key = lists[left]
    low = left
    high = right
    while left < right:
        while left < right and lists[right] >= key:
            right -= 1
        lists[left] = lists[right]
        while left < right and lists[left] <= key:
            left += 1
        lists[right] = lists[left]
    lists[right] = key
    quick_sort(lists, low, left - 1)
    quick_sort(lists, left + 1, high)
    return lists

一行版---- 利用序列切片

import numpy as np
# 生成随机序列
randomList = np.random.randint(500,size=100)
print(randomList)

def qsort(numbers):
    if len(numbers) == 0: return []
    else: return qsort([i for i in numbers[1:] if i <= numbers[0]]) + [numbers[0]] + qsort([i for i in numbers[1:] if i > numbers[0]])

qsort(randomList)

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,922评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,591评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,546评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,467评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,553评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,580评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,588评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,334评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,780评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,092评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,270评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,925评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,573评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,194评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,437评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,154评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,005评论 25 707
  • 今日分享 极简主义者产生的条件,主要是有三个: 1.泛滥的信息和物质 打开手机,可以了解到各种信息,信息量爆炸式增...
    雪23阅读 111评论 0 0
  • 哈喽大家好.我是林森.今天我给大家分享的是社群营销! 从2013年至今,投身微商的行业的人数愈2000万,微商形势...
    艾丽森阅读 360评论 0 0
  • 随着年纪的增长,并且由于工作的原因,近来,我越来越认识到拥有一副健康的体魄是多么重要。25岁,年轻,可是感觉突然要...
    清空Q阅读 390评论 0 0
  • 有时候还上的空气可新鲜啦,我有时候还在海面上拿上。我的救生圈我每次都在海面上游泳。我不知道为什么?我都还不知道还可...
    谢运生阅读 216评论 0 0