国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > Python > 正文

python二分法查找算法實(shí)現(xiàn)方法【遞歸與非遞歸】

2024-09-09 19:03:00
字體:
供稿:網(wǎng)友

本文實(shí)例講述了python二分法查找算法實(shí)現(xiàn)方法。分享給大家供大家參考,具體如下:

二分法查找

二分查找又稱折半查找,優(yōu)點(diǎn)是比較次數(shù)少,查找速度快,平均性能好;其缺點(diǎn)是要求待查表為有序表,且插入刪除困難。因此,折半查找方法適用于不經(jīng)常變動(dòng)而查找頻繁的有序列表。首先,假設(shè)表中元素是按升序排列,將表中間位置記錄的關(guān)鍵字與查找關(guān)鍵字比較,如果兩者相等,則查找成功;否則利用中間位置記錄將表分成前、后兩個(gè)子表,如果中間位置記錄的關(guān)鍵字大于查找關(guān)鍵字,則進(jìn)一步查找前一子表,否則進(jìn)一步查找后一子表。重復(fù)以上過程,直到找到滿足條件的記錄,使查找成功,或直到子表不存在為止,此時(shí)查找不成功。

二分法查找實(shí)現(xiàn)

(非遞歸實(shí)現(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 Falsetestlist = [0, 1, 2, 8, 13, 17, 19, 32, 42,]print(binary_search(testlist, 3))print(binary_search(testlist, 13))

(遞歸實(shí)現(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))

運(yùn)行結(jié)果:

False
True

時(shí)間復(fù)雜度

最優(yōu)時(shí)間復(fù)雜度:O(1) 最壞時(shí)間復(fù)雜度:O(logn)

更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python列表(list)操作技巧總結(jié)》、《Python編碼操作技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python入門與進(jìn)階經(jīng)典教程》

希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 襄樊市| 大冶市| 灵宝市| 临清市| 海城市| 土默特左旗| 沂南县| 万年县| 乃东县| 青阳县| 大方县| 东辽县| 清镇市| 和田县| 民丰县| 永胜县| 保山市| 安图县| 昭通市| 汾阳市| 廉江市| 新民市| 康马县| 卓资县| 金阳县| 八宿县| 墨江| 荥阳市| 丁青县| 宣威市| 竹山县| 厦门市| 寻乌县| 南汇区| 商河县| 鄂伦春自治旗| 城口县| 扎赉特旗| 柳江县| 中山市| 外汇|