用java写一个折半查找_用Java写一个折半查找。
import java.util.Comparator;
public class MyUtil {
public static > int binarySearch(T[] x, T key) {
return binarySearch(x, 0, x.length- 1, key);
}
// 使用循環(huán)實現(xiàn)的二分查找
public static int binarySearch(T[] x, T key, Comparator comp) {
int low = 0;
int high = x.length - 1;
while (low <= high) {
int mid = (low + high) >>> 1;
int cmp = comp.compare(x[mid], key);
if (cmp < 0) {
low= mid + 1;
}
else if (cmp > 0) {
high= mid - 1;
}
else {
return mid;
}
}
return -1;
}
// 使用遞歸實現(xiàn)的二分查找
private static> int binarySearch(T[] x, int low, int high, T key) {
if(low <= high) {
int mid = low + ((high -low) >> 1);
if(key.compareTo(x[mid])== 0) {
return mid;
}
else if(key.compareTo(x[mid])< 0) {
return binarySearch(x,low, mid - 1, key);
}
else {
return binarySearch(x,mid + 1, high, key);
}
}
return -1;
}
}
說明:上面的代碼中給出了折半查找的兩個版本,一個用遞歸實現(xiàn),一個用循環(huán)實現(xiàn)。需要注意的是計算中間位置時不應(yīng)該使用(high+ low) / 2的方式,因為加法運算可能導(dǎo)致整數(shù)越界,這里應(yīng)該使用以下三種方式之一:low + (high – low) / 2或low + (high – low) >> 1或(low + high) >>> 1(>>>是邏輯右移,是不帶符號位的右移)
總結(jié)
以上是生活随笔為你收集整理的用java写一个折半查找_用Java写一个折半查找。的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: win10打印机显示安装错误怎么解决办法
- 下一篇: java美元兑换,(Java实现) 美元