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

首頁(yè) > 學(xué)院 > 開(kāi)發(fā)設(shè)計(jì) > 正文

Ruby實(shí)現(xiàn)二分搜索(二分查找)算法的簡(jiǎn)單示例

2019-10-26 19:29:59
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

在計(jì)算機(jī)科學(xué)中,二分搜索(英語(yǔ):binary search),也稱(chēng)折半搜索(英語(yǔ):half-interval search)、對(duì)數(shù)搜索(英語(yǔ):logarithmic search),是一種在有序數(shù)組中查找某一特定元素的搜索算法。搜索過(guò)程從數(shù)組的中間元素開(kāi)始,如果中間元素正好是要查找的元素,則搜索過(guò)程結(jié)束;如果某一特定元素大于或者小于中間元素,則在數(shù)組大于或小于中間元素的那一半中查找,而且跟開(kāi)始一樣從中間元素開(kāi)始比較。如果在某一步驟數(shù)組為空,則代表找不到。這種搜索算法每一次比較都使搜索范圍縮小一半。

復(fù)雜度分析
時(shí)間復(fù)雜度:
折半搜索每次把搜索區(qū)域減少一半,時(shí)間復(fù)雜度為201672171630230.png (57×31)。(n代表集合中元素的個(gè)數(shù))
空間復(fù)雜度:
201672171655530.png (39×25)雖以遞歸形式定義,但是尾遞歸,可改寫(xiě)為循環(huán)。

Ruby代碼示例

def binseaech(arr, i)  low, high = 0, arr.size - 1  while (low < high)    mid = (low + high)/2    if arr[mid] < i      low = mid + 1    elsif arr[mid] > i      high = mid - 1    else      return mid    end  endendarr = [1,3,12,34,35,46,91,108]puts binseaech(arr, 91)

結(jié)果:

6[Finished in 0.1s]

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 桐庐县| 冀州市| 宝清县| 汉沽区| 原平市| 家居| 开化县| 个旧市| 日土县| 启东市| 老河口市| 临潭县| 格尔木市| 新民市| 镇江市| 德安县| 周至县| 昭平县| 将乐县| 河南省| 辰溪县| 武义县| 日喀则市| 达拉特旗| 定结县| 青浦区| 湘阴县| 沾益县| 武邑县| 海淀区| 马关县| 广州市| 高要市| 龙泉市| 新巴尔虎右旗| 合水县| 聂拉木县| 芷江| 宿松县| 慈溪市| 东至县|