美文网首页
二分查找代码框架

二分查找代码框架

作者: 木木与呆呆 | 来源:发表于2022-07-13 14:29 被阅读0次

1.基本的二分查找

public static int binarySearch(int[] nums, int target) {
    int left = 0;
    int right = nums.length - 1;
    if (target < nums[left] || target > nums[right]) {
        return -1;
    }

    while (left <= right) {
        int mid = left + (right - left) / 2;
        if (nums[mid] < target) {
            left = mid + 1;
        } else if (nums[mid] > target) {
            right = mid - 1;
        } else if (nums[mid] == target) {
            return mid;
        }
        // 注意"else if (nums[mid] == target)"该条件可不写
        // 直接写else也是对的
    }
    return -1;
}

2.寻找左侧边界的二分查找

public static int leftBound(int[] nums, int target) {
    int left = 0;
    int right = nums.length - 1;
    if (target < nums[left] || target > nums[right]) {
        return -1;
    }

    while (left <= right) {
        int mid = left + (right - left) / 2;
        if (nums[mid] < target) {
            left = mid + 1;
        } else if (nums[mid] > target) {
            right = mid - 1;
        } else if (nums[mid] == target) {
            // 不能返回,锁定左边界,继续缩小右边界
            right = mid - 1;
        }
        // 上面的"right = mid - 1;"代码体相同,
        // 判断条件可以合并为else if (nums[mid] >= target)
    }
    return nums[left] == target ? left : -1;
}

3.寻找右侧边界的二分查找

public static int rightBound(int[] nums, int target) {
    int left = 0;
    int right = nums.length - 1;
    if (target < nums[left] || target > nums[right]) {
        return -1;
    }

    while (left <= right) {
        int mid = left + (right - left) / 2;
        if (nums[mid] < target) {
            left = mid + 1;
        } else if (nums[mid] > target) {
            right = mid - 1;
        } else if (nums[mid] == target) {
            // 不能返回,锁定右边界,继续缩小左边界
            left = mid + 1;
        }
        // 上面的"left = mid + 1;"代码体相同,
        // 判断条件可以合并为else if (nums[mid] <= target)
    }
    return nums[right] == target ? right : -1;
}

4.说明

这是一个Java实现的二分查找法,
包括其基本的二分查找法及其两个变种,
找到最左边第1个等于target的二分法,
找到最右边最后一个等于target的二分法。

分析上面的代码可以发现
其区别在于nums[mid] == target时的处理,
基本二分法找到即会立刻返回;
查找左边界时,需要不断收缩右边界,直到找到最左边;
查找右边界时,需要不断收缩左边界,直到找到最右边。

5.测试代码

package edu.yuwen.algorithms.binarysearch;

public class BinarySearch {

    public static void main(String[] args) {
        int nums[] = { 1, 2, 3, 3, 3, 4, 5, 6 };
        int mid = binarySearch(nums, 3);
        System.out.println("1.binary search=" + mid);

        mid = leftBound(nums, 3);
        System.out.println("2.left bound=" + mid);

        mid = rightBound(nums, 3);
        System.out.println("3.right bound=" + mid);
    }
}

输出结果如下:

1.binary search=3
2.left bound=2
3.right bound=4

相关文章

  • 二分查找代码框架

    1.基本的二分查找 2.寻找左侧边界的二分查找 3.寻找右侧边界的二分查找 4.说明 这是一个Java实现的二分查...

  • 二分查找(变体)代码框架

    1.说明 前面介绍了二分查找代码框架[https://www.jianshu.com/p/6423f7367615...

  • python笔试面试项目实战2020百练1二分查找法(虾皮面试题

    题目1:请补充完整如下非递归二分查找的代码 题目2:请补充完整如下递归二分查找的代码 基础 二分查找是一种算法,其...

  • 查找算法

    查找算法 1顺序查找 2二分查找 2.1二分查找思路分析 2.2代码实现 3插值查找 3.1插值查找原理介绍: ​...

  • 二分查找

    网上找到的图片便于理解 二分查找递归实现与循环实现代码: /** 二分查找 1.二分查找又称折半查找,它是一种效率...

  • 704. Binary Search

    思路:标准的二分查找框架 练习指数:5

  • 查找

    查找一般要掌握顺序查找、二分查找、哈希表查找和二叉排序树查找。要能够快速准确地写出二分查找的代码。 1. 顺序查找...

  • LeetCode 数组专题 1:二分查找

    二分查找法 说明:二分查找法在代码实现上有模板方法,一定要掌握。 1、二分查找法的使用前提:数组一定要是排好序的,...

  • 数据结构与算法系列 (5) 查找算法

    1.概述 2.常见的查找算法 2.1 顺序(线性)查找 2.1.2 代码示例 2.2 二分查找/折半查找 2.2....

  • 二分查找(折半查找)

    二分查找源代码(Java) package sort; public class serach { public ...

网友评论

      本文标题:二分查找代码框架

      本文链接:https://www.haomeiwen.com/subject/olftirtx.html