更新时间:2024-03-08 来源:黑马程序员 浏览量:
递归二分查找是一种经典的查找算法,用于在有序数组中查找特定元素的位置。下面是用Java实现递归二分查找的详细说明:
public class BinarySearch { // 递归二分查找方法 public static int binarySearch(int[] arr, int target) { return binarySearch(arr, target, 0, arr.length - 1); } // 辅助递归方法 private static int binarySearch(int[] arr, int target, int low, int high) { // 当low大于high时,说明整个数组已经搜索完毕,但未找到目标元素 if (low > high) { return -1; } // 计算中间元素的索引 int mid = low + (high - low) / 2; // 如果中间元素等于目标值,则返回该元素的索引 if (arr[mid] == target) { return mid; } // 如果中间元素大于目标值,则在左半部分继续查找 else if (arr[mid] > target) { return binarySearch(arr, target, low, mid - 1); } // 如果中间元素小于目标值,则在右半部分继续查找 else { return binarySearch(arr, target, mid + 1, high); } } public static void main(String[] args) { int[] arr = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; int target = 6; int result = binarySearch(arr, target); if (result != -1) { System.out.println("目标元素 " + target + " 的索引为: " + result); } else { System.out.println("目标元素 " + target + " 不存在于数组中。"); } } }
在这个实现中,我们有两个方法:
1.binarySearch(int[] arr, int target):
这个方法是公开的二分查找方法,它调用了辅助递归方法,并传入了数组、目标值以及数组的起始和结束索引。
2.binarySearch(int[] arr, int target, int low, int high):
这个方法是私有的辅助递归方法。它接受一个数组、目标值以及搜索范围的起始和结束索引。在每一次递归调用中,它计算中间元素的索引,然后与目标值进行比较。如果找到目标值,则返回其索引;否则,根据目标值与中间元素的大小关系,递归地在左半部分或右半部分继续查找。
在main方法中,我们展示了如何使用这个二分查找算法。我们声明了一个有序数组arr,并指定了目标值 target,然后调用binarySearch方法来搜索目标值在数组中的位置。最后,根据返回的结果,输出相应的信息。