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

主頁(yè) > 知識(shí)庫(kù) > Ruby實(shí)現(xiàn)二分搜索(二分查找)算法的簡(jiǎn)單示例

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

熱門標(biāo)簽:武漢呼叫中心外呼系統(tǒng)線路商 北京語音電銷機(jī)器人價(jià)格 買了外呼系統(tǒng)不想用了怎么辦 電話機(jī)器人電話卡封號(hào)怎么辦 樂昌電話機(jī)器人 真人語音電銷機(jī)器人系統(tǒng) 浦東上海400開頭的電話申請(qǐng) 邯鄲外呼調(diào)研線路 開封百應(yīng)電銷機(jī)器人聯(lián)系方式

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

復(fù)雜度分析
時(shí)間復(fù)雜度:
折半搜索每次把搜索區(qū)域減少一半,時(shí)間復(fù)雜度為。(n代表集合中元素的個(gè)數(shù))
空間復(fù)雜度:
雖以遞歸形式定義,但是尾遞歸,可改寫為循環(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
  end
end

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

結(jié)果:

6
[Finished in 0.1s]

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

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Ruby實(shí)現(xiàn)二分搜索(二分查找)算法的簡(jiǎn)單示例》,本文關(guān)鍵詞  Ruby,實(shí)現(xiàn),二分,搜索,查找,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Ruby實(shí)現(xiàn)二分搜索(二分查找)算法的簡(jiǎn)單示例》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Ruby實(shí)現(xiàn)二分搜索(二分查找)算法的簡(jiǎn)單示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 伊春市| 芷江| 老河口市| 拜城县| 班玛县| 呼和浩特市| 鹰潭市| 成都市| 巴楚县| 鹤山市| 凤山市| 抚州市| 贵德县| 黄大仙区| 铜梁县| 嘉荫县| 马山县| 卫辉市| 土默特左旗| 神农架林区| 土默特左旗| 米林县| 梁平县| 额敏县| 淮南市| 石嘴山市| 阿城市| 咸丰县| 新丰县| 奇台县| 彭阳县| 宜昌市| 合川市| 祥云县| 星子县| 永胜县| 阳曲县| 泽州县| 曲水县| 惠水县| 酉阳|