// 二分查找算法的Java实现
public class BinarySearch {
// 定义一个方法,用于在有序数组中进行二分查找
public static int binarySearch(int[] array, int target) {
int left = 0; // 左边界
int right = array.length - 1; // 右边界
while (left <= right) {
int mid = left + (right - left) / 2; // 计算中间位置,防止溢出
if (array[mid] == target) {
return mid; // 找到目标值,返回其索引
} else if (array[mid] < target) {
left = mid + 1; // 目标值在右半部分
} else {
right = mid - 1; // 目标值在左半部分
}
}
return -1; // 如果没有找到目标值,返回-1
}
// 测试代码
public static void main(String[] args) {
int[] sortedArray = {1, 3, 5, 7, 9, 11, 13, 15};
int target = 7;
int result = binarySearch(sortedArray, target);
if (result != -1) {
System.out.println("元素 " + target + " 在数组中的索引为: " + result);
} else {
System.out.println("元素 " + target + " 不在数组中");
}
}
}
binarySearch 方法接收一个有序数组 array 和一个目标值 target,返回目标值在数组中的索引。如果目标值不在数组中,则返回 -1。left 和 right 分别表示当前搜索范围的左右边界。mid 是当前搜索范围的中间位置,使用 left + (right - left) / 2 避免了直接计算 (left + right) / 2 可能导致的整数溢出问题。array[mid] == target,则找到了目标值,返回其索引。array[mid] < target,说明目标值在右半部分,更新 left。array[mid] > target,说明目标值在左半部分,更新 right。main 方法中,我们创建了一个有序数组,并调用 binarySearch 方法来查找目标值 7,最后输出结果。希望这段代码和解释对你有帮助!
上一篇:java byte类型
Laravel PHP 深圳智简公司。版权所有©2023-2043 LaravelPHP 粤ICP备2021048745号-3
Laravel 中文站