Ruby实现二分搜索(二分查找)算法的简单示例

所属分类: 脚本专栏 / ruby专题 阅读数: 428
收藏 0 赞 0 分享

在计算机科学中,二分搜索(英语: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
  end
end

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

结果:

6
[Finished in 0.1s]

更多精彩内容其他人还在看

Ruby简明教程之循环语句介绍

这篇文章主要介绍了Ruby简明教程之循环语句介绍,非常简洁的讲解,可以作为语法备忘,需要的朋友可以参考下
收藏 0 赞 0 分享

Ruby简明教程之判断语句介绍

这篇文章主要介绍了Ruby简明教程之判断语句介绍,非常简洁的讲解,可以作为语法备忘,需要的朋友可以参考下
收藏 0 赞 0 分享

Ruby简明教程之数组和Hash介绍

这篇文章主要介绍了Ruby简明教程之数组和Hash介绍,非常简洁的讲解,可以作为语法备忘,需要的朋友可以参考下
收藏 0 赞 0 分享

Ruby简明教程之方法(Method)介绍

这篇文章主要介绍了Ruby简明教程之方法(Method)介绍,ruby的方法分为实例方法、类方法、函数方法等,本文分别做了讲解,需要的朋友可以参考下
收藏 0 赞 0 分享

Ruby字符串、条件、循环、数组、Hash、类基本操作笔记

这篇文章主要介绍了Ruby字符串、条件、循环、数组、Hash、类基本操作笔记,需要的朋友可以参考下
收藏 0 赞 0 分享

Ruby中字符串左侧补零方法实例

这篇文章主要介绍了Ruby中字符串左侧补零方法实例,常用的方法是使用字符的rjust方法来实现,需要的朋友可以参考下
收藏 0 赞 0 分享

Rails脚手架使用实例

这篇文章主要介绍了Rails脚手架使用实例,通过8个步骤来实现一个完整案例,需要的朋友可以参考下
收藏 0 赞 0 分享

rails上传图片代码实例

这篇文章主要介绍了rails上传图片代码实例,包含model层和view层的代码,需要的朋友可以参考下
收藏 0 赞 0 分享

rails创建应用程序实例

这篇文章主要介绍了rails创建应用程序实例,本文从零开始教你完成一个rails网站应用的创建过程,需要的朋友可以参考下
收藏 0 赞 0 分享

rails常用数据库查询操作、方法浅析

这篇文章主要介绍了rails常用数据库查询操作、方法浅析,总结的比较全,WEB开发种常用的数据库操作都列出了rails对应代码,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多