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;
  }
}
相关推荐
_oP_i18 分钟前
Oracle JDK(通常简称为 JDK)和 OpenJDK区别
java·数据库·oracle
seabirdssss18 分钟前
力扣_876. 链表的中间结点
java·数据结构·算法·leetcode·链表
SEO-狼术18 分钟前
Enhance your XML editing experience Crack
xml·java·前端
IT-sec24 分钟前
tomcat 文件上传 (CVE-2017-12615)
java·安全·web安全·网络安全·tomcat·系统安全
JhonKI30 分钟前
【算法】BFS解决最短路径问题
算法·php·宽度优先
i7i8i9com32 分钟前
baomidou Mabatis plus引入异常
java·开发语言·mybatis
weixin_4467077439 分钟前
使用easyexcel导出复杂模板,同时使用bean,map,list填充
java·excel·easyexcel
通义灵码1 小时前
如何用通义灵码快速绘制流程图?
java·python·流程图·visual studio·通义灵码
小蒜学长1 小时前
springboot视频网站系统的设计与实现(代码+数据库+LW)
java·数据库·spring boot·后端·spring
续写少年!1 小时前
自定义注解
java·开发语言