Python實(shí)現(xiàn)算法(一)

1.二分查找

def binary_search(mylist, item):
    low = 0
    high = len(mylist)-1
    while low <= high:
        mid = (low + high)//2     # 如果(low + high)//2不是偶數(shù)褪迟,Python自動(dòng)將mid向下圓整。
        guess = mylist[mid]
        if guess == item:
            return mid
        if guess > item:          # 猜的數(shù)大了
            high = mid - 1
        else:                     # 猜的數(shù)小了
            low = mid + 1
    return None


my_list = [1, 3, 4, 5, 7, 9]
print(binary_search(my_list, 3))

大O 表示法指出了最糟情況下的運(yùn)行時(shí)間.(除最糟情況下的運(yùn)行時(shí)間外,還應(yīng)考慮平均情況的運(yùn)行時(shí)間城榛,這很重要土童。最糟情況和平均情況將在后面討論)
這里順帶說一下簡(jiǎn)單查找法的算法運(yùn)行時(shí)間為O(n),而二分查找法的運(yùn)行時(shí)間為O(log n)

2.選擇排序

def findSmallest(arr):
    """找出數(shù)組中最小元素的函數(shù)"""
    smallest = arr[0]              # 存儲(chǔ)最小的值
    smallest_index = 0             # 存儲(chǔ)最小的值的索引
    for i in range(1, len(arr)):
        if arr[i] < smallest:
            smallest = arr[i]
            smallest_index = i
    return smallest_index

def selectionSort(arr):
    """現(xiàn)在可以使用這個(gè)函數(shù)來編寫選擇排序算法了"""
    newArr = []
    for i in range(len(arr)):
        smallest = findSmallest(arr)      # 找出數(shù)組中最小的元素,并將其加入到新數(shù)組中
        newArr.append(arr.pop(smallest))
    return newArr

print(selectionSort([5, 3, 6, 2, 10]))

選擇排序算法運(yùn)行時(shí)間為O(n2)

3.快速排序

def quicksort(array):
    if len(array) < 2:
        return array        # 基線條件:為空或只包含一個(gè)元素的數(shù)組是“有序”的
    else:
        pivot = array[0]    # 遞歸條件
        less = [i for i in array[1:] if i <= pivot]    # 由所有小于基準(zhǔn)值的元素組成的子數(shù)組
        greater = [i for i in array[1:] if i > pivot]  # 由所有大于基準(zhǔn)值的元素組成的子數(shù)組
        return quicksort(less) + [pivot] + quicksort(greater)

print(quicksort([10, 5, 2, 3]))

快速排序算法運(yùn)行時(shí)間為O(nlog n)
注:何為平均情況,何為最糟情況呢? 快速排序的性能高度依賴于你選擇的基準(zhǔn)條件,快速排序算法最糟糕的情況下運(yùn)行時(shí)間為O(n2),最佳情況為O(nlog n),最佳情況也是平均情況.只要你每次都隨機(jī)地選擇一個(gè)數(shù)組元素作為基準(zhǔn)值,快速排序的平均運(yùn)行時(shí)間就將為O(n log n)阱驾。快速排序是最快的排序算法之一,也是D&C (divide and conquer)典范.

關(guān)于大O表示法,算法時(shí)間復(fù)雜度,可查看這個(gè)鏈接https://stackoverflow.com/questions/487258/what-is-a-plain-english-explanation-of-big-o-notation

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末渡冻,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子宜雀,更是在濱河造成了極大的恐慌,老刑警劉巖简烘,帶你破解...
    沈念sama閱讀 219,366評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件覆旭,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡七兜,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門腕铸,熙熙樓的掌柜王于貴愁眉苦臉地迎上來惜犀,“玉大人,你說我怎么就攤上這事狠裹∷浣纾” “怎么了酪耳?”我有些...
    開封第一講書人閱讀 165,689評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)碗暗。 經(jīng)常有香客問我,道長(zhǎng)晴圾,這世上最難降的妖魔是什么噪奄? 我笑而不...
    開封第一講書人閱讀 58,925評(píng)論 1 295
  • 正文 為了忘掉前任死姚,我火速辦了婚禮勤篮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘碰缔。我一直安慰自己,他們只是感情好瀑焦,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,942評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著榛瓮,像睡著了一般。 火紅的嫁衣襯著肌膚如雪精续。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,727評(píng)論 1 305
  • 那天驻右,我揣著相機(jī)與錄音崎淳,去河邊找鬼愕把。 笑死拣凹,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的恨豁。 我是一名探鬼主播,決...
    沈念sama閱讀 40,447評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼菊匿,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼计福!你這毒婦竟也來了跌捆?” 一聲冷哼從身側(cè)響起象颖,我...
    開封第一講書人閱讀 39,349評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤说订,失蹤者是張志新(化名)和其女友劉穎抄瓦,沒想到半個(gè)月后陶冷,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,820評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡煞额,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,990評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了壁袄。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,127評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡嗜逻,死狀恐怖缭召,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情嵌巷,我是刑警寧澤,帶...
    沈念sama閱讀 35,812評(píng)論 5 346
  • 正文 年R本政府宣布靡努,位于F島的核電站晓折,受9級(jí)特大地震影響惑朦,放射性物質(zhì)發(fā)生泄漏漓概。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,471評(píng)論 3 331
  • 文/蒙蒙 一梁肿、第九天 我趴在偏房一處隱蔽的房頂上張望觅彰。 院中可真熱鬧吩蔑,春花似錦缔莲、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽擅憔。三九已至檐晕,卻和暖如春暑诸,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背个榕。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工西采, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留凰萨,地道東北人械馆。 一個(gè)月前我還...
    沈念sama閱讀 48,388評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像珊搀,于是被迫代替她去往敵國(guó)和親尾菇。 傳聞我的和親對(duì)象是個(gè)殘疾皇子境析,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,066評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容