Java中Binary Search如何实现

1146
2024/6/28 5:02:28
栏目: 编程语言
开发者测试专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

在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的大小关系来更新leftright的值,直到找到目标元素或者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表示未找到。

辰迅云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

推荐阅读: Java中ArrayList类常用方法和遍历是什么