论坛首页 综合技术论坛

运用插值法解决静态查找问题

浏览 2145 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2009-03-02   最后修改:2009-03-03

静态查找问题描述为:给定一个整数和一个数组,查找该整数在这个数组中的位置或返回一个不存在的标志,在查找过程中数组中的数据是不变的。例如在一个电话号码本里查找某一个人。如果数组中的数据是无序的,我们只能用顺序查找来检查数组中的每一个值,直到找到一个匹配的为止。如果数组中的数据已经排过序,就可以使用二分搜索来代替顺序查找。二分搜索每次都是从给定查找范围的中间开始而不是从端点开始,这样可以提高查找效率。二分搜索在查找一个有序的静态数组时很快,是我们经常使用的方法。但是如果我们要查找的值在靠近端点的位置,这时再使用二分搜索显然是不明智的。这时就可以使用更快的一种查找方法插值法。插值法不是简单地使用中间值来查找,而是要对查找值所在的位置做一个正确的猜测,来确定要查找的一下项。

下面是插值法的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.

论坛首页 综合技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics