Search in unknown size array
public class Solution {
public int search(Dictionary dict, int target) {
if (dict == null) return -1;
if (dict.get(1) == null){
return dict.get(0) == target ? 0 : -1;
}
int left = 0;
int right = 1;
//double right until we know target is within range of left->right
while(dict.get(right) != null && dict.get(right) < target){
left = right;
right = 2 * right;
}
return binarySearch(dict, target, left, right);
}
private int binarySearch(Dictionary dict, int target, int left, int right){
while(left <= right){
int mid = left + (right - left) / 2;
if (dict.get(mid) == null || dict.get(mid) > target){
right = mid - 1;
} else if (dict.get(mid) < target){
left = mid + 1;
} else {
return mid;
}
}
return -1;
}
}Last updated