package com.jwetherell.algorithms.search; /** * Interpolation search is an algorithm for searching for a given key in an indexed array that has been ordered by numerical values assigned to the keys (key values). It parallels how humans search * through a telephone book for a particular name, the key value by which the book's entries are ordered. *

* Worst-case performance O(n)
* Average performance O(log(log(n)))
*
* https://en.wikipedia.org/wiki/Interpolation_search * * @author Justin Wetherell */ public class InterpolationSearch { private static int[] sorted = null; // Assuming the array is sorted public static final int find(int value, int[] array) { InterpolationSearch.sorted = array; try { return recursiveFind(value, 0, InterpolationSearch.sorted.length - 1); } finally { InterpolationSearch.sorted = null; } } private static int recursiveFind(int value, int start, int end) { if (start == end) { int lastValue = sorted[start]; // start==end if (value == lastValue) return start; // start==end return Integer.MAX_VALUE; } final int mid = start + ((value - sorted[start]) * (end - start)) / (sorted[end] - sorted[start]); if (mid < 0 || mid > end) return Integer.MAX_VALUE; int midValue = sorted[mid]; if (value == midValue) return mid; if (value > midValue) return recursiveFind(value, mid + 1, end); return recursiveFind(value, start, mid - 1); } }