Leetcode 解题模版 - Binary Search

适用场景

一种针对有序区间内的O(logN)的搜索方式,最常见用于已经排好序的Array

解题模版

ini 复制代码
public int binarySearch(int[] arr, int k) {
  int l = 0, r = arr.length - 1;
  while(l <= r) {
    //int mid = (l + r) / 2;   normally avoid since it might overflow for int
    int mid = l + (r - l) / 2;
    if(arr[mid] == k) {
      return mid; 
    } else if (arr[mid] > k) {
      r = mid - 1;
    } else {
      l = mid + 1;
    }
  }
  return -1;  
}

三大模版:

  1. 找一个准确值:

<1> 循环条件: l <= r

<2> 缩减搜索空间:

l = mid + 1

r = mid - 1

  1. 找一个模糊值(比4大的数字, first occurrence of 2)

<1> 循环条件:l < r

<2> 缩减搜索空间:

l = mid

r = mid - 1

or

l = mid + 1

r = mid

  1. 万用型

<1> 循环条件:l < r - 1

<2> 缩减搜索空间:

l = mid

r = mid

变换场景

找一个模糊值

e.g. the first occurance of 2

ini 复制代码
public int binarySearch(int[] arr, int k) {
  int l = 0, r = arr.length - 1;
  while(l < r) {
    int mid = l + (r - l) / 2;
    if(arr[mid] < k) {
      l = mid + 1;
    } else {
      r = mid;
    }
  }
  return l;
}

e.g. last occurrence of 2

ini 复制代码
public int binarySearch(int[] arr, int k) {
  int l = 0, r = arr.length - 1;
  while(l < r) {
    int mid = l + (r - l + 1) / 2;
    if(arr[mid] > k) {
      r = mid - 1;
    } else {
      l = mid;
    }
  }
  return r;
}

万用型 (closest to 2)

<1> 循环条件:l < r - 1

<2> 缩减搜索空间:

l = mid

r = mid

ini 复制代码
public int binarySearch(int[] arr, int k) {
  int l = 0, r = arr.length - 1;
  while(l < r - 1) {
    int mid = l + (r - l) / 2;
    if(arr[mid] < k) 
      l = mid;
    else
      r = mid;
  }

  //upon determine the l/r, compare the value
  if(arr[r] < k) {
    return r;
  } else if(arr[l] > k) {
    return l;
  } else {
    return k - arr[l] > arr[r] - k ? r : l;
  }
}
相关推荐
NAGNIP13 小时前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试
NAGNIP13 小时前
一文搞懂激活函数!
算法·面试
董董灿是个攻城狮13 小时前
AI 视觉连载7:传统 CV 之高斯滤波实战
算法
前端Hardy18 小时前
面试官:JS数组的常用方法有哪些?这篇总结让你面试稳了!
javascript·面试
日月云棠19 小时前
各版本JDK对比:JDK 25 特性详解
java
牛奶19 小时前
React 底层原理 & 新特性
前端·react.js·面试
牛奶19 小时前
ts随笔:面向对象与高级类型
前端·面试·typescript
牛奶19 小时前
React 基础理论 & API 使用
前端·react.js·面试
爱理财的程序媛20 小时前
openclaw 盯盘实践
算法