在Java中,可以使用递归或迭代的方式实现二分搜索算法。以下是一个使用迭代方式实现的示例代码:
public static int binarySearch(int[] arr, int target) {
int left = 0;
int right = arr.length - 1;
while (left <= right) {
int mid = left + (right - left) / 2;
if (arr[mid] == target) {
return mid;
} else if (arr[mid] < target) {
left = mid + 1;
} else {
right = mid - 1;
}
}
return -1; // 如果找不到目标元素,则返回-1
}
在这段代码中,arr
是一个已经排序的数组,target
是要查找的目标元素。在每一次迭代中,我们计算中间元素的索引mid
,然后根据arr[mid]
与target
的大小关系来更新left
和right
的值,直到找到目标元素或者left > right
为止。如果找到目标元素,则返回它的索引,否则返回-1表示未找到。
另外,也可以使用递归的方式实现二分搜索算法,递归的实现方式如下:
public static int binarySearchRecursive(int[] arr, int target) {
return binarySearchRecursive(arr, target, 0, arr.length - 1);
}
private static int binarySearchRecursive(int[] arr, int target, int left, int right) {
if (left > right) {
return -1;
}
int mid = left + (right - left) / 2;
if (arr[mid] == target) {
return mid;
} else if (arr[mid] < target) {
return binarySearchRecursive(arr, target, mid + 1, right);
} else {
return binarySearchRecursive(arr, target, left, mid - 1);
}
}
在这段代码中,binarySearchRecursive
方法是一个重载方法,它接受一个数组arr
和目标元素target
作为参数,并调用了另一个私有方法binarySearchRecursive
来执行实际的搜索。在私有方法中,我们使用递归的方式来执行二分搜索,直到找到目标元素或者left > right
为止。如果找到目标元素,则返回它的索引,否则返回-1表示未找到。