静态查找问题描述为:给定一个整数和一个数组,查找该整数在这个数组中的位置或返回一个不存在的标志,在查找过程中数组中的数据是不变的。例如在一个电话号码本里查找某一个人。如果数组中的数据是无序的,我们只能用顺序查找来检查数组中的每一个值,直到找到一个匹配的为止。如果数组中的数据已经排过序,就可以使用二分搜索来代替顺序查找。二分搜索每次都是从给定查找范围的中间开始而不是从端点开始,这样可以提高查找效率。二分搜索在查找一个有序的静态数组时很快,是我们经常使用的方法。但是如果我们要查找的值在靠近端点的位置,这时再使用二分搜索显然是不明智的。这时就可以使用更快的一种查找方法插值法。插值法不是简单地使用中间值来查找,而是要对查找值所在的位置做一个正确的猜测,来确定要查找的一下项。
下面是插值法的boo实现:
import System
def interpolationSearch(obj as int, *args as (int)):
low = 0
high = args.Length - 1
next as int
while low < high:
//to determine the position of the next item
next = low + ((obj - args[low]) / (args[high] - args[low])) * (high - low - 1)
if args[next] < obj:
low = next + 1
else:
high = next
if args[low] == obj:
return low
return -1
>>>a = array(range(3, 1000)) ... >>>interpolationSearch(85, *a) 82 >>>
上面在数组a中查找85所在的位置,返回82.
本文介绍了一种高效的查找算法——插值查找法,并通过实例演示了其在有序数组中的应用。相较于二分查找,插值查找能更准确预测目标位置,尤其适用于查找值位于数组端点附近的情况。
1万+

被折叠的 条评论
为什么被折叠?



