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

首頁 > 編程 > 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]

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 商城县| 安康市| 平利县| 甘谷县| 梁山县| 辰溪县| 绥宁县| 行唐县| 武冈市| 昭苏县| 青海省| 沧州市| 临桂县| 沅江市| 云浮市| 寿宁县| 伊金霍洛旗| 南城县| 松桃| 仙桃市| 巴塘县| 德兴市| 尼木县| 黑龙江省| 肇庆市| 荆州市| 灵石县| 江达县| 化州市| 郸城县| 牡丹江市| 高青县| 石首市| 鸡泽县| 道孚县| 邹平县| 邹平县| 方城县| 玉屏| 贞丰县| 剑河县|