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;
  }
}
相关推荐
YGGP7 分钟前
【Golang】LeetCode 169. 多数元素
算法·leetcode
风月歌9 分钟前
小程序项目之校园二手交易平台小程序源代码(源码+文档)
java·数据库·mysql·小程序·毕业设计·源码
顾安r10 分钟前
11.20 脚本网页 数学分支
算法·数学建模·html
少许极端14 分钟前
算法奇妙屋(二十)-回文子串/子序列问题(动态规划)
java·算法·动态规划·图解·回文串·回文序列
有味道的男人16 分钟前
1688数据采集:官方API与网页爬虫实战指南
java·服务器·爬虫
仅此,21 分钟前
前端接收了id字段,发送给后端就变了
java·前端·javascript·spring·typescript
天赐学c语言22 分钟前
12.20 - 反转链表II && 传值和传地址的区别
数据结构·c++·算法·链表·leecode
@淡 定22 分钟前
AQS在锁实现中的应用详解
java
如意鼠23 分钟前
大模型教我成为大模型算法工程师之day20: 预训练语言模型 (Pre-trained Language Models)
人工智能·算法·语言模型
_OP_CHEN23 分钟前
【算法基础篇】(三十六)图论基础之拓扑排序:从原理到实战,搞定 DAG 图的 “先后次序” 难题
c++·算法·蓝桥杯·图论·拓扑排序·算法竞赛·acm/icpc