当前位置: 首页 > news >正文

二分答案(求最大值的最小值||求最小值的最大值)

引入

二分答案要建立在二分查找的基础上,在此之前,要知道二分查找的三个模板

  • 模板一
while(l<r)
{int mid=(l+r)>>1;if(check(mid)) r=mid;else l=mid+1;
}
  • 模板二
while(l<r)
{int mid=l+r+1>>1;if(check(mid)) l=mid;else r=mid-1;
}
  • 模板三
while(r-l<1e-5)
{double mid = (l+r)/2;if(check(mid)) l=mid; //或r=mid;else r=mid; //或l=mid;
}

正文

二分查找是建立在一个单调性的范围内,三分是二分求导以后单调,即求极值,二分答案是答案在具有一定的单调性,所以二分答案只有两个要做的事情,一是选择模板,二是写check函数,具体内容具体分析

如何选择模板?

求…最大值的最小 、 求…最小值的最大。
1、求…最大值的最小,我们二分答案(即二分最大值)的时候,判断条件满足后,尽量让答案往前来(即:让r=mid),对应模板1;
2、同样,求…最小值的最大时,我们二分答案(即二分最小值)的时候,判断条件满足后,尽量让答案往后走(即:让l=mid),对应模板2;

http://www.lryc.cn/news/179897.html

相关文章:

  • 思维模型 周期
  • 从 0 到 1 ,手把手教你编写《消息队列》项目(Java实现) —— 介绍项目/ 需求分析
  • Python学习之索引与切片
  • 编程每日一练(多语言实现)基础篇:满足abcd=(ab+cd)^2的数 (增加Go语言实现)
  • LeetCode 热题 HOT 100:回溯专题
  • 喝健康白酒 有益生心健康
  • 动态规划:两个数组的dp问题(C++)
  • BASH shell脚本篇2——条件命令
  • 【图论C++】Floyd算法(多源最短路径长 及 完整路径)
  • 小谈设计模式(11)—模板方法模式
  • C#程序中很多ntdll.dll、clr.dll的线程
  • 低代码工作流程管理系统:提升企业运营效率的利器
  • HIVE SQL regexp_extract和regexp_replace配合使用正则提取多个符合条件的值
  • debian 安装matlab2022b报错解决方法与问题解决思路
  • Jenkins集成AppScan实现
  • 10.1 File类
  • [论文笔记]UNILM
  • LLM之Colossal-LLaMA-2:Colossal-LLaMA-2的简介、安装、使用方法之详细攻略
  • 国庆作业2
  • fork仓库的代码如何同步主仓库代码
  • 【Axure】元件库和母版、常见的原型规范、静态原型页面制作
  • 在设备树中描述中断
  • ccf_csp第一题汇总
  • uniapp 实现下拉筛选框 二次开发定制
  • 实现单行/多行文本溢出
  • Spring Boot中的Binder类
  • leetcode之打家劫舍
  • 走进Spring的世界 —— Spring底层核心原理解析(一)
  • 快看看你的手机有没有:谷歌Android全面封杀此类软件!
  • spark ui 指南