欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

Python的快速排序 逐步深入

系統(tǒng) 1823 0

因?yàn)橛幸粋€(gè)先入為主的概念:快速排序最牛。因此剛開始一聽見快速 排序就不敢寫,認(rèn)為其絕對(duì)很復(fù)雜。

事實(shí)證明這種想法不能有!

簡單粗暴地使用遞歸手寫快速排序:

(為了面試時(shí)候能不怯場的直接手撕)

            
              # 簡單粗暴的快速排序
# 存在額外的開銷存放左右
# 要多次遍歷數(shù)組
def quicksort(array):  # 直接遞歸
    if len(array)<2:   # 遞歸出口
        return array
    pivot_index = 0
    pivot = array[pivot_index]
    left_arr = [i for i in array[pivot_index+1:] if i<=pivot]
    right_arr = [i for i in array[pivot_index+1:] if i>pivot]
    return quicksort(left_arr) + [pivot] + quicksort(right_arr)

# 測試
import random
# seq = list(range(10))
# random.shuffle(seq)
seq = [random.randint(1,100) for i in range(10)]
print(seq)
quicksort(seq)
    
            
          

輸出:?

            
              [4, 77, 14, 14, 33, 69, 63, 67, 87, 9]
[4, 9, 14, 14, 33, 63, 67, 69, 77, 87]

            
          

改進(jìn):

上述算法存在很多問題,已經(jīng)寫在注釋里。因此考慮不創(chuàng)建額外數(shù)組的改進(jìn):

思路概述:

  1. 以第一個(gè)元素作為pivot,left指針指向第二個(gè)元素,right指針指向最后一個(gè)元素。
  2. 如果left指向的元素小于pivot,則left指針+1(即后移一個(gè)元素),接著判斷,如果該元素大于pivot,left指針停止移動(dòng)。
  3. 如果right指向的元素大于pivot,則right指針-1(即前移一個(gè)元素),接著判斷,如果該元素小于pivot,right指針停止移動(dòng)。
  4. 判斷l(xiāng)eft是否大于right,是就跳出
  5. 交換left和right所指向的元素。
  6. 返回步驟2.
  7. 跳出后,交換right所指和pivot所在位置的值。
            
              # 改進(jìn),不產(chǎn)生多余的開銷
# 在原數(shù)組上用左右指針
def partition(array,beg,end): # pivot左邊的都比pivot小,右邊的都比pivot大
    pivot_index = beg
    pivot = array[pivot_index]
    left = pivot_index+1
    right = end
    
    while True:
        while left<=right and array[left]<=pivot:
            left += 1
        while left<=right and array[right]>pivot:
            right -=1
        if left>right:
            break
        else:
            array[left],array[right] = array[right],array[left]
    array[right],array[pivot_index] = array[pivot_index],array[right]
    return right              # 返回pivot的下標(biāo)
    
def quicksort_pro(array,beg,end):   # 改進(jìn)后的快速排序
    if beg < end :
        pivot = partition(array,beg,end)
        quicksort_pro(array,beg,pivot)
        quicksort_pro(array,pivot+1,end)
        
# 測試
import random
# seq = list(range(10))
# random.shuffle(seq)
seq = [random.randint(1,100) for i in range(6)]
print(seq)
quicksort_pro(seq,0,len(seq)-1)
print(seq)
    
            
          

以上。

參考:

https://www.bilibili.com/video/av26524049

https://www.bilibili.com/video/av26524633/?spm_id_from=trigger_reload

?


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: av网站在线免费观看 | 天天草夜夜爽 | 色香首页| 日韩亚洲第一页 | 国产精品久久久久久久一区探花 | 国产欧美一区二区视频 | 国产成人精品区一区二区不卡 | 久草精品免费 | 欧美一区二区三区免费视频 | 成人免费网站在线观看 | 成人免费视频网站在线观看 | 色欲AV蜜臀AV在线观看麻豆 | 成人练习生演员 | 国产精品高清m3u8在线播放 | 日韩成人在线视频 | 蜜桃精品久久久久久久免费影院 | 一区二区三区高清在线观看 | 毛片91| 欧美精品v国产精品v日韩精品 | 久草视频在线观 | 欧美18videosex性视频 | 很黄很暴力深夜爽爽无遮挡 | 中国一级大黄大黄大色毛片 | 久久精品伊人 | 亚洲国产欧洲综合997久久 | 日韩成人在线观看视频 | 农村寡妇偷人高潮A片小说 午夜爱爱爱爱爽爽爽网站免费 | 99久在线观看 | 国产日韩欧美在线观看 | 色综合久久98天天综合 | 亚洲成人av一区二区 | 欧美123 | 亚洲午夜精品视频 | a高清免费毛片久久 | 午夜精品久久久久久 | 久久黄视频 | 一级做a视频 | 污污视频免费网站 | 伦一区二区三区中文字幕v亚洲 | 久久国产天堂福利天堂 | 久久精品亚洲 |