【二分算法】-- 三种二分模板总结

文章目录

  • [1. 特点](#1. 特点)
  • [2. 学习中的侧重点](#2. 学习中的侧重点)
    • [2.1 算法原理](#2.1 算法原理)
    • [2.2 模板](#2.2 模板)
      • [2.2.1 朴素二分模板(easy-->有局限)](#2.2.1 朴素二分模板(easy-->有局限))
      • [2.2.2 查找左边界的二分模板](#2.2.2 查找左边界的二分模板)
      • [2.2.3 查找右边界的二分模板](#2.2.3 查找右边界的二分模板)

1. 特点

二分算法是最恶心,细节最多,最容易写出死循环的算法====但是,一旦掌握了之后,二分算法就是最简单的算法。

其实并不是一定要二分,三分,四分也都可以,但是根据概率学中的求期望数学中可知,二分是效率最高的。

如果是三分的话,我们就像是在赌,如果赌对了,那么就直接舍弃掉三分之二的数据,但是如果失败了那么就只能舍弃掉三分之一的数据。

2. 学习中的侧重点

2.1 算法原理

只有在数组有序的情况下才能使用二分算法(×)。

实际情况是,只要能发现一些规律(二段性)就能使用二分算法。

2.2 模板

不要死记硬背×3!!!------>理解之后再记忆。

2.2.1 朴素二分模板(easy-->有局限)

java 复制代码
while (left <= right){//条件一定是带等号的
   int mid = left + ((right - left)/2);//防止溢出
    if (.....){
        left = mid + 1;
    } else if (.....) {
        right = mid - 1;
    }else {
        return .....;
    }
}

2.2.2 查找左边界的二分模板

细节处理:

  1. 循环条件
    left < right
  • left = right的时候,就是最终结果,无需判断。
  • 如果判断,就会死循环
  1. 求中点的操作
    left + (right - left) / 2
java 复制代码
while (left < right){
    int mid = left + (left - right) / 2;
    if (....){
        left = mid + 1;
    }else{
        right = mid;
    }
}

2.2.3 查找右边界的二分模板

细节处理:

  1. 循环条件
    left < right
  • left = right的时候,就是最终结果,无需判断。
  • 如果判断,就会死循环
  1. 求中点的操作
    left + (right - left + 1) / 2
java 复制代码
while (left < right){
    int mid = left + (left - right + 1) / 2;
    if (....){
        left = mid;
    }else{
        right = mid - 1;
    }
}

第2和3种模板是万能模板,但是细节比较多。
记忆:当下面出现 - 1 时,上面就加 + 1

相关推荐
手握风云-1 天前
Spring AI:让大模型住进 Spring 生态(三)
java·后端·spring
深邃-1 天前
【数据结构与算法】-二叉树(2):实现顺序结构二叉树(堆的实现),向上调整算法,向下调整算法,堆排序,TOP-K问题
数据结构·算法·二叉树·排序算法·堆排序··top-k
咸鱼2.01 天前
【java入门到放弃】Dubbo
java·开发语言·dubbo
We་ct1 天前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
JAVA面经实录9171 天前
Java企业级工程化·终极完整版背诵手册(无遗漏、全覆盖、面试+落地通用)
java·开发语言·面试
王老师青少年编程1 天前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
周杰伦fans1 天前
AutoCAD .NET 二次开发:深入理解 EntityJig 的工作原理与正确实现
开发语言·.net
叼烟扛炮1 天前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说1 天前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
许彰午1 天前
CacheSQL(二):主从复制——OpLog 环形缓冲区与故障自动恢复
java·数据库·缓存