Take out a piece of paper. We’ll be programming on paper.
/**
* @return the index of value in the sorted array data, or -1 if value is not in the array.
*/
public static int binarySearch(E[] data, E value, Comparator<E> c) { // the data array is sorted.
// your code here.
// you can use a recursive helper method
}
The binary search algorithm decides which half of the array the value is in by comparing the value to the middle of the array then searching the correct half.