17.二分查找

1.非遞歸實現(xiàn)

def binary_search(alist, item):
    first = 0
    last = len(alist) - 1
    while first <= last:
        midpoint = (first + last) // 2
        if alist[midpoint] == item:
            return True
        elif item < alist[midpoint]:
            last = midpoint - 1
        else:
            first = midpoint + 1
    return False
testlist = [0, 1, 2, 8, 13, 17, 19, 32, 42, ]
print(binary_search(testlist, 3))
print(binary_search(testlist, 13))

# 運行結果
False
True

2.遞歸實現(xiàn)

def binary_search(alist, item):
    if len(alist) == 0:
        return False
    else:
        midpoint = len(alist) // 2
        if alist[midpoint] == item:
            return True
        else:
            if item < alist[midpoint]:
                return binary_search(alist[:midpoint], item)
            else:
                return binary_search(alist[midpoint + 1:], item)

testlist = [0, 1, 2, 8, 13, 17, 19, 32, 42, ]
print(binary_search(testlist, 3))
print(binary_search(testlist, 13))

# 運行結果
False
True
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末娩缰,一起剝皮案震驚了整個濱河市娘侍,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌挣输,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,482評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件殷勘,死亡現(xiàn)場離奇詭異亚隙,居然都是意外死亡,警方通過查閱死者的電腦和手機子漩,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來石洗,“玉大人幢泼,你說我怎么就攤上這事〗采溃” “怎么了缕棵?”我有些...
    開封第一講書人閱讀 152,762評論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀的道長涉兽。 經(jīng)常有香客問我招驴,道長,這世上最難降的妖魔是什么枷畏? 我笑而不...
    開封第一講書人閱讀 55,273評論 1 279
  • 正文 為了忘掉前任别厘,我火速辦了婚禮,結果婚禮上拥诡,老公的妹妹穿的比我還像新娘触趴。我一直安慰自己,他們只是感情好渴肉,可當我...
    茶點故事閱讀 64,289評論 5 373
  • 文/花漫 我一把揭開白布冗懦。 她就那樣靜靜地躺著,像睡著了一般宾娜。 火紅的嫁衣襯著肌膚如雪批狐。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,046評論 1 285
  • 那天前塔,我揣著相機與錄音嚣艇,去河邊找鬼。 笑死华弓,一個胖子當著我的面吹牛食零,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播寂屏,決...
    沈念sama閱讀 38,351評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼贰谣,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了迁霎?” 一聲冷哼從身側(cè)響起吱抚,我...
    開封第一講書人閱讀 36,988評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎考廉,沒想到半個月后秘豹,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,476評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡昌粤,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,948評論 2 324
  • 正文 我和宋清朗相戀三年既绕,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片涮坐。...
    茶點故事閱讀 38,064評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出捆毫,到底是詐尸還是另有隱情棚点,我是刑警寧澤,帶...
    沈念sama閱讀 33,712評論 4 323
  • 正文 年R本政府宣布捷雕,位于F島的核電站椒丧,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏非区。R本人自食惡果不足惜瓜挽,卻給世界環(huán)境...
    茶點故事閱讀 39,261評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望征绸。 院中可真熱鬧久橙,春花似錦、人聲如沸管怠。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽渤弛。三九已至祝拯,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背佳头。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評論 1 262
  • 我被黑心中介騙來泰國打工鹰贵, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人康嘉。 一個月前我還...
    沈念sama閱讀 45,511評論 2 354
  • 正文 我出身青樓碉输,卻偏偏與公主長得像,于是被迫代替她去往敵國和親亭珍。 傳聞我的和親對象是個殘疾皇子敷钾,可洞房花燭夜當晚...
    茶點故事閱讀 42,802評論 2 345

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