麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Ruby > 正文

Ruby實現二分搜索(二分查找)算法的簡單示例

2020-10-29 19:34:30
字體:
來源:轉載
供稿:網友

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

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

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)

結果:

6[Finished in 0.1s]

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 91久久91久久精品免观看 | 一级观看免费完整版视频 | av懂色 | 欧美日韩亚洲另类 | 精品一区二区三区网站 | 欧美人与zoxxxx另类9 | 久久99国产精品久久99果冻传媒 | 亚洲精品午夜电影 | 成人福利在线视频 | 日日鲁一鲁视频 | 国产精品午夜小视频观看 | 一级成人免费 | 精品91av | 青草久久久久 | a视频在线免费观看 | 精品国产一区二区三区在线观看 | 久国久产久精永久网页 | 91社区在线观看 | 国产午夜亚洲精品 | 久久伊人精品视频 | 成人男女啪啪免费观看网站四虎 | 国产精品视频自拍 | 国产va在线观看 | 操你逼| 精品国产一区在线观看 | 一级做受毛片免费大片 | free japan xxxxhdsex69| 成人免费午夜视频 | 婷婷久久久久久 | 久久精品国产99久久久古代 | 精品国产一区二区三区蜜殿 | 99精品国产小情侣高潮露脸在线 | japanese hot milf free av | 色妞视频男女视频 | 一区二区久久 | 亚洲自拍第一 | 在线免费91 | 中文字幕在线观看视频www | 亚洲视频在线一区二区 | 免费国产羞羞网站视频 | 日韩一级片免费 |