二分查找,递归和非递归

前言:对于排好序的关键字的查找,通常使用二分查找,时间复杂度为O(logn)

1.思想

  • 设数组区间为low到high,对于目标数,先查看数组中间元素,及下标为(low+high)/2的元素是否匹配
  • 若是则返回,若目标元素较小,则在low到high-1区间查找
  • 若目标元素较大,则在low+1到high区间查找

2.代码

public class BinarySearch {

    public static void main(String[] args) {
        int[] data = {2,4,5,6,8,9,12,54,564};
        System.out.println(binarySearch(data, 2));
    }

    //iterative
    public static int binarySearch(int[] data, int target) {
        int low = 0, high = data.length-1;
        int mid;
        while (low <= high) {
            mid = (low + high) / 2;
            if (data[mid] == target) {
                return mid;
            }
            else if (target < data[mid]) {
                high = mid - 1;
            }
            else {
                low = mid + 1;
            }
        }
        return -1;
    }

    //recursive
    public static int binarySearch(int[] data, int low, int high, int target) {
        if (low <= high) {
            int mid = (low + high) / 2;
            if (target == data[mid]) {
                return mid;
            }
            else if (target < data[mid]) {
                return binarySearch(data, low, mid-1, target);
            }
            else {
                return binarySearch(data, mid+1, high, target);
            }
        }
        return -1;
    }
}
二分查找是一种常用的查找算法,可以在有序的数组中快速查找目标元素,其时间复杂度为 O(log n)。在实现二分查找时,可以采用递归非递归的方式。 递归实现二分查找的过程: 1. 如果 low > high,则表示查找失败,返回 -1。 2. 如果 low <= high,则计算 mid = low + (high - low) / 2,即中间位置的下标。 3. 如果 arr[mid] 等于目标元素 target,则直接返回 mid。 4. 如果 arr[mid] 大于目标元素 target,则在前半部分继续查找,即递归调用 binarySearch(arr, low, mid - 1, target)。 5. 如果 arr[mid] 小于目标元素 target,则在后半部分继续查找,即递归调用 binarySearch(arr, mid + 1, high, target)。 非递归实现二分查找的过程: 1. 如果 low > high,则表示查找失败,返回 -1。 2. 如果 low <= high,则计算 mid = low + (high - low) / 2,即中间位置的下标。 3. 如果 arr[mid] 等于目标元素 target,则直接返回 mid。 4. 如果 arr[mid] 大于目标元素 target,则在前半部分继续查找,即将 high 更新为 mid - 1。 5. 如果 arr[mid] 小于目标元素 target,则在后半部分继续查找,即将 low 更新为 mid + 1。 6. 重复步骤 1~5,直到找到目标元素或查找失败。 递归非递归实现的二分查找算法本质上是一样的,只是实现方式不同。相对而言,递归实现简单易懂,但由于递归调用可能会产生大量的函数调用开销,因此在处理大规模数据时,非递归实现更为高效。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值