校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > Ruby實現二分搜索(二分查找)算法的簡單示例

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

熱門標簽:武漢呼叫中心外呼系統線路商 北京語音電銷機器人價格 買了外呼系統不想用了怎么辦 電話機器人電話卡封號怎么辦 樂昌電話機器人 真人語音電銷機器人系統 浦東上海400開頭的電話申請 邯鄲外呼調研線路 開封百應電銷機器人聯系方式

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

復雜度分析
時間復雜度:
折半搜索每次把搜索區域減少一半,時間復雜度為。(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
  end
end

arr = [1,3,12,34,35,46,91,108]
puts binseaech(arr, 91)

結果:

6
[Finished in 0.1s]

您可能感興趣的文章:
  • Ruby實現的各種排序算法
  • ruby實現的插入排序和冒泡排序算法
  • Ruby實現的矩陣連乘算法
  • Ruby實現的3種快速排序算法
  • Ruby實現的合并排序算法
  • Ruby實現的最優二叉查找樹算法
  • Ruby實現的圖片濾鏡算法代碼

標簽:石嘴山 宜春 松原 淄博 六安 鄂州 河北 自貢

巨人網絡通訊聲明:本文標題《Ruby實現二分搜索(二分查找)算法的簡單示例》,本文關鍵詞  Ruby,實現,二分,搜索,查找,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Ruby實現二分搜索(二分查找)算法的簡單示例》相關的同類信息!
  • 本頁收集關于Ruby實現二分搜索(二分查找)算法的簡單示例的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 海晏县| 马龙县| 台东县| 图们市| 高州市| 固镇县| 汤原县| 溆浦县| 洞口县| 许昌市| 浏阳市| 凤凰县| 漾濞| 张家界市| 新闻| 米泉市| 锦州市| 白玉县| 镇坪县| 平舆县| 青海省| 安徽省| 古交市| 抚顺县| 新化县| 晋江市| 中超| 新乡县| 太保市| 若尔盖县| 阿图什市| 福安市| 饶阳县| 乐都县| 平遥县| 瑞昌市| 张家港市| 鄱阳县| 大厂| 贞丰县| 子长县|