二分搜索算法详解(Binary Search)

二分搜索(Binary Search)

  • 如何确定一个元素在数组中的位置?(假设数组里面全都是整数)

  • 如果是无序数组,从第0个位置开始遍历搜索,平均时间复杂度:O(n)
    在这里插入图片描述

  • 如果是有序数组,可以使用二分搜索,最坏时间复杂度为O(logn)
    在这里插入图片描述

(一)、二分搜索 — 思路

  • 假设在[beginend)范围内搜索某个元素 vmid == (begin + end)/ 2
    ①、如果v < m,去[beginmid)范围内二分搜索
    ②、如果v > m,去[mid + 1, end)范围内二分搜索
    ③、如果v == m ,直接返回 mid
  • end指的是数组的长度。
    在这里插入图片描述

(二)、二分搜索 — 实例

在这里插入图片描述
在这里插入图片描述

(三)、二分搜索 — 实现

import org.junit.Test;
import java.util.Arrays;

/**
* 查找v在有序数组array中的位置
*/
public class BinarySearch {
    public int indexOf(int[] array, int v){
        if (array == null || array.length == 0) return -1;
        int begin = 0;
        int end = array.length;
        while (begin < end){
            int mid = (begin + end) >> 1;
            if (v < array[mid]){
                end = mid;
            }else if (v > array[mid]){
                begin = mid+1;
            }else {
                return mid;
            }
        }
        return -1;
    }
    @Test
    public void test(){
        int[] array = {2,4,8,8,9,13,10};
        System.out.println(Arrays.toString(array));
        System.out.println(indexOf(array,8));
    }
}
运行结果:
[2, 4, 6, 8, 9, 13, 10]
3
  • 思考???
    如果存在多个重复的值,返回的是哪一个?
  • 例如:[2,4, 8, 8, 9, 13, 10]
    我们通过运行上述的代码,可以看到,它的返回值是3,而不是2,因此我们可以得出结论如果存在多个重复的值,返回的值不确定。

(四)、二分搜索优化

  • 在元素 v 的插入过程中,可以先用二分搜索出合适的插入位置,然后再将元素v插入。
    在这里插入图片描述
  • 要求二分搜索返回的插入位置:第1个大于 v 的元素位置
    ①、如果 v 是 5,返回 2
    ②、如果 v 是 1,返回 0
    ③、如果 v 是 15,返回 7
    ④、如果 v 是 8,返回 5

(1)、二分搜索优化 — 思路

  • 假设在[beginend)范围内搜索某个元素 vmid == (begin + end)/ 2
    ①、如果v < m,去[beginmid)范围内二分搜索
    ②、如果v >= m,去[mid + 1, end)范围内二分搜索
  • end指的是数组的长度。
    在这里插入图片描述

(2)、 二分搜索优化 — 实例

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

import org.junit.Test;
import java.util.Arrays;

public class BinarySearch {
    /**
     * 查找v在有序数组array中待插入位置
     */
    public static int search(int[] array, int v){
        if (array == null || array.length == 0) return -1;

        int begin = 0;
        int end = array.length;
        while (begin < end){
            int mid = (begin + end) >> 1;
            if (v < array[mid]){
                end = mid;
            }else{
                begin = mid+1;
            }
        }
        return begin;
    }

    @Test
    public void test2(){
        int[] array = {2,4,8,8,8,12,14};
        System.out.println(Arrays.toString(array));
        System.out.println(search(array,5) == 2);
        System.out.println(search(array,1) == 0);
        System.out.println(search(array,15) == 7);
        System.out.println(search(array,8) == 5);
    }
}
运行结果:
[2, 4, 8, 8, 8, 12, 14]
true
true
true
true
  • 52
    点赞
  • 275
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
以下是Java中实现二分搜索算法的示例: ```java public class BinarySearch { 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; } public static void main(String[] args) { int[] arr = {1, 2, 3, 4, 5, 6, 7, 8, 9}; int target = 6; int result = binarySearch(arr, target); if (result == -1) { System.out.println("Element not found"); } else { System.out.println("Element found at index " + result); } } } ``` 这个示例中,我们定义了一个`binarySearch`方法来执行二分搜索算法。该方法接受一个有序数组和目标元素作为参数,并返回目标元素在数组中的索引(如果存在),否则返回-1。 在`binarySearch`方法中,我们使用两个指针`left`和`right`来表示搜索范围的左右边界。然后,我们在每次迭代中计算中间元素的索引`mid`,并将其与目标元素进行比较。如果中间元素等于目标元素,则返回其索引。如果中间元素小于目标元素,则将左指针移到中间元素的右侧。如果中间元素大于目标元素,则将右指针移到中间元素的左侧。通过不断缩小搜索范围,最终可以找到目标元素或确定其不存在。 在示例的`main`方法中,我们创建了一个有序数组`arr`和一个目标元素`target`。然后,我们调用`binarySearch`方法来搜索目标元素,并根据返回的结果打印相应的消息。
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值