二分查找的循环写法与递归写法

2020-07-24  本文已影响0人  好学人

二分查找

二分查找也称折半查找(Binary Search),它是一种效率较高的查找方法。但二分查找要求线性表必须采用顺序存储结构,而且表中元素按关键字有序排列。

适用范围:有序列表

时间复杂度:O(logn)

循环写法

/**
 * 二分查找的循环写法(升序列表)
 */
public int binarySearch(int[] array, int target) {
    int left = 0;
    int right = array.length - 1;
    while (left <= right) { // 在候选区有效时循环查找
        int middle = (left + right) / 2;
        if (array[middle] == target) {
            return middle; // 找到目标元素
        } else if (array[middle] > target) {
            // 在左侧区域查找
            left = left;
            right = middle - 1;
        } else {
            // 在右侧区域查看
            left = middle + 1;
            right = right;
        }
    }
    return -1; // 未找到目标元素
}

递归写法

/**
 * 二分查找的递归写法(升序列表)
 */
public int binarySearch(int[] array, int target, int left, int right) {
    if (left > right) {
        return -1; // 未找到目标元素
    }
    int middle = (left + right) / 2;
    if (array[middle] == target) {
        return middle; // 找到目标元素
    } else if (array[middle] > target) {
        return binarySearch(array, target, left, middle - 1); // 在左侧区域递归查找
    } else {
        return binarySearch(array, target, middle + 1, right); // 在右侧区域递归查找
    }
}
上一篇下一篇

猜你喜欢

热点阅读