¿Puedo obtener ayuda, por favor? He intentado muchos métodos para que esto funcione. Obtuve la matriz ordenada e imprimida, pero después de eso mi función de búsqueda binaria no quiere funcionar y me da los resultados correctos. Siempre me da -1. ¿Alguna ayuda?Java BinarySearch
public class BinarySearch {
public static final int NOT_FOUND = -1;
public static int binarySearch(double[] a, double key) {
int low = 0;
int high = a.length -1;
int mid;
while (low<=high) {
mid = (low+high) /2;
if (mid > key)
high = mid -1;
else if (mid < key)
low = mid +1;
else
return mid;
}
return NOT_FOUND;
}
public static void main(String[] args) {
double key = 10.5, index;
double a[] ={10,5,4,10.5,30.5};
int i;
int l = a.length;
int j;
System.out.println("The array currently looks like");
for (i=0; i<a.length; i++)
System.out.println(a[i]);
System.out.println("The array after sorting looks like");
for (j=1; j < l; j++) {
for (i=0; i < l-j; i++) {
if (a[i] > a[i+1]) {
double temp = a[i];
a[i] = a[i+1];
a[i+1] = temp;
}
}
}
for (i=0;i < l;i++) {
System.out.println(a[i]);
}
System.out.println("Found " + key + " at " + binarySearch(double a[], key));
}
}
me paso en un depurador a través del código y ver por qué no se comporta de la manera adecuada. por cierto. Un error que es poco probable que encuentre por su cuenta es que el medio debe ser 'mid = (low + high) >>> 1;' También lo compararía con el código de Arrays.binarySearch en el JDK, ya que funciona y es casi lo mismo. ;) –