基础二分学习笔记

模板 : 

 个人倾向第一种 ;

 

 

 

 整数二分 : 

最大化查找 :

可行区域在左侧 : 查找最后一个<=q的数的下标 : 

int find(int q){// 查找最后一个 <= q 的下标 int l = 0 , r = n + 1 ;while(l + 1 < r){int mid = l + r >> 1 ;if(a[mid]<=q) l = mid ;else r = mid ;}return l ;
}

 最小化查找 : 

可行区域在右侧 : 查找第一个>=q的数的下标 :
 

int find(int q){ // 查找第一个>=q的下标 int l = 0 , r = n + 1 ;while(l + 1 < r){int mid = l + r >> 1 ;if(a[mid]>=q) r = mid ;else l = mid ;}return r;
}

浮点数二分 : 

double find(double l, double r){const double eps = 1e-6; // eps 表示精度,取决于题目对精度的要求while (r - l > eps){double mid = (l + r) / 2;if (check(mid)) r = mid;else l = mid;}return l;
}

以求一个浮点数(-10000 <= y <= 10000) 的三次方根 为例:

double find(double y){ // 最大化查找 double l = -100 , r = 100 ;while(r-l>1e-5){double mid = (l + r) / 2 ;if(mid * mid * mid <= y) l = mid;else r = mid ;}return l ;
} 

例题 : 

35 . 搜索插入位置

. - 力扣(LeetCode)

最小化查找 : 

class Solution {
public:int searchInsert(vector<int>& nums, int target) {// 第一个 >= target 的下标int n = nums.size() ;int l = -1 , r = n ;while(l + 1 < r){// l + 1 == n 结束int mid = l + r >> 1 ;if(nums[mid]>=target) r = mid ;else l = mid ;}// nums[r] ;return r ; }
};

P2249 【深基13.例1】查找

【深基13.例1】查找 - 洛谷

最小化查找 : 

#include<bits/stdc++.h>
using namespace std ;
const int N = 1e6 + 10 ;
int a[N] ;
int main(){int n , m ; cin >> n >> m ; for(int i=1;i<=n;i++) cin >> a[i] ;while(m--){int q ; cin >> q ;int l = 0 , r = n + 1 ;while(l + 1 < r){int mid = l + r >> 1 ;if(a[mid] >= q) r = mid ;else l = mid ;}if(a[r]==q) cout << r << " " ;else cout << -1 << " " ;}
}

P1024 [NOIP2001 提高组] 一元三次方程求解

[NOIP2001 提高组] 一元三次方程求解 - 洛谷

浮点数二分 : 

#include<bits/stdc++.h>
using namespace std ;
const int N = 1e6 + 10 ;double a , b , c , d ; double f(double x){return a * x * x * x + b * x * x + c * x + d ;	
}double find(double l , double r){while(r-l>0.0001){double mid = (l + r) / 2 ;if(f(mid) * f(r) < 0) l = mid ;else r = mid ;}return l ;
}int main(){cin >> a >> b >> c >> d ;for(int i=-100;i<100;i++){double y1 = f(i) , y2 = f(i + 1) ;if(!y1) printf("%.2f ",1.0 * i) ;if(y1 * y2 < 0){printf("%.2f " , find(i , i + 1)) ;}}
}

学习视频地址 : 

A05 二分查找算法 最好的板子_哔哩哔哩_bilibili

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/717754.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

django settings.py STATICFILES_FINDERS 设置

STATICFILES_FINDERS 定义查找器后端以确保Django能够正确地定位和提供静态文件是很重要的. Django中的STATICFILES FINDERS设置是一个inder后端列表&#xff0c;它知道如何在不同的位置定位静态文件。 它被Django的静态文件处理系统用来在开发和部署过程中查找和收集静态文件…

js json转换成字符串

js中JSON数据转换成字符串&#xff0c;可以使用JSON.stringify()方法。 var obj {name: "张三", age: 18, gender: "男"}; var jsonString JSON.stringify(obj); console.log(jsonString); // 输出 {"name":"张三","age"…

土壤类型数据

国家地球系统科学数据中心

AGM CPLD (AGRV2K )的时钟(外部时钟和片上内部振荡器)

AGM CPLD &#xff08;AGRV2K &#xff09;的时钟(外部时钟和片上内部振荡器) 外部晶振 与 内部振荡器&#xff1a; mcu 和 cpld 联合编程时&#xff0c; 整颗芯片需要一颗外部晶振。 &#xff08;芯片有内部振荡器&#xff0c; 但误差较大&#xff0c; 校准后 5%以内误差&…

216. 组合总和 III(力扣LeetCode)

文章目录 216. 组合总和 III回溯算法 216. 组合总和 III 找出所有相加之和为 n 的 k 个数的组合&#xff0c;且满足下列条件&#xff1a; 只使用数字1到9每个数字 最多使用一次 返回 所有可能的有效组合的列表 。该列表不能包含相同的组合两次&#xff0c;组合可以以任何顺序…

Electron通过预加载脚本从渲染器访问Node.js

问题&#xff1a;如何实现输出Electron的版本号和它的依赖项到你的web页面上&#xff1f; 答案&#xff1a;在主进程通过Node的全局 process 对象访问这个信息是微不足道的。 然而&#xff0c;你不能直接在主进程中编辑DOM&#xff0c;因为它无法访问渲染器 文档 上下文。 它们…

【软考】数据库的三级模式

目录 一、概念1.1 说明1.2 数据库系统体系结构图 二、外模式三、概念模式四、内模式 一、概念 1.1 说明 1.数据的存储结构各不相同&#xff0c;但体系结构基本上具有相同的特征&#xff0c;采用三级模式和两级镜像 2.数据库系统设计员可以在视图层、逻辑层和物理层对数据进行抽…

matplotlib散点图

matplotlib散点图 假设通过爬虫你获取到了北京2016年3, 10月份每天白天的最高气温(分别位于列表a, b), 那么此时如何寻找出气温和随时间(天)变化的某种规律? from matplotlib import pyplot as pltx_3 range(1, 32) x_10 range(51, 82)y_3 [11,17,16,11,12,11,12,6,6,7,8…

试手一下CameraX(APP)

书接上回。 首先还是看谷歌的官方文档&#xff1a; https://developer.android.com/media/camera/camerax?hlzh-cn https://developer.android.com/codelabs/camerax-getting-started?hlzh-cn#1 注&#xff1a;这里大部分内容也来自谷歌文档。 官方文档用的是Kotlin&…

常用的字符字符串的读取方法(C / C++)

一、字符 1、读取单个字符&#xff1a;直接读取 //输入a //读取 char x; scanf("%c",&x); 2、读取带空格的字符 h h h 按格式书写格式化字符串即可 char a,b,c; scanf("%c %c %c",&a,&b,&c); 3、 处理字符间的换行符 假设要读取以…

Day14:信息打点-主机架构蜜罐识别WAF识别端口扫描协议识别服务安全

目录 Web服务器&应用服务器差异性 WAF防火墙&安全防护&识别技术 蜜罐平台&安全防护&识别技术 思维导图 章节知识点 Web&#xff1a;语言/CMS/中间件/数据库/系统/WAF等 系统&#xff1a;操作系统/端口服务/网络环境/防火墙等 应用&#xff1a;APP对象/…

小程序图形:echarts-weixin 入门使用

去官网下载整个项目&#xff1a; https://github.com/ecomfe/echarts-for-weixin 拷贝ec-canvs文件夹到小程序里面 index.js里面的写法 import * as echarts from "../../components/ec-canvas/echarts" const app getApp(); function initChart(canvas, width, h…

Vscode 使用SSH远程连接树莓派的教程(解决卡在Downloading with wget)

配置Vscode Remote SSH 安装OpenSSH 打开Windows开始页面&#xff0c;直接进行搜索PowerShell&#xff0c;打开第一个Windows PowerShell&#xff0c;点击以管理员身份运行 输入指令 Get-WindowsCapability -Online | ? Name -like OpenSSH* 我是已经安装好了&#xff0c;…

学会玩游戏,智能究竟从何而来?

最近在读梅拉妮米歇尔《AI 3.0》第三部分第九章&#xff0c;谈到学会玩游戏&#xff0c;智能究竟从何而来&#xff1f; 作者: [美] 梅拉妮米歇尔 出版社: 四川科学技术出版社湛庐 原作名: Artificial Intelligence: A Guide for Thinking Humans 译者: 王飞跃 / 李玉珂 / 王晓…

基于springboot实现计算机类考研交流平台系统项目【项目源码+论文说明】

基于springboot实现计算机类考研交流平台系统演示 摘要 高校的大学生考研是继高校的高等教育更上一层的表现形式&#xff0c;教育的发展是我们社会的根本&#xff0c;那么信息技术的发展又是改变我们生活的重要因素&#xff0c;生活当中各种各样的场景都存在着信息技术的发展。…

程序员超强大脑——更好地解决编程问题(二)

概念机器 概念机器是计算机的抽象表征&#xff0c;可以借此分析计算机执行的操作。 程序员不仅经常借助概念机器推理计算机的运行方式&#xff0c;而且往往用它来分析代码。例如&#xff0c;虽然并不存在能够出存储数值的实体&#xff0c;但程序员还是会将变量描述为“保存”…

Debezium发布历史163

原文地址&#xff1a; https://debezium.io/blog/2023/09/23/flink-spark-online-learning/ 欢迎关注留言&#xff0c;我是收集整理小能手&#xff0c;工具翻译&#xff0c;仅供参考&#xff0c;笔芯笔芯. Online machine learning with the data streams from the database …

SpringBlade CVE-2022-27360 export-user SQL 注入漏洞分析

漏洞描述 SpringBlade是一个基于Spring Cloud和Spring Boot的开发框架&#xff0c;旨在简化和加速微服务架构的开发过程。它提供了一系列开箱即用的功能和组件&#xff0c;帮助开发人员快速构建高效可靠的微服务应用。该产品/api/blade-user/export-user接口存在SQL注入。 漏…

Java - List集合与Array数组的相互转换

一、List 转 Array 使用集合转数组的方法&#xff0c;必须使用集合的 toArray(T[] array)&#xff0c;传入的是类型完全一样的数组&#xff0c;大小就是 list.size() public static void main(String[] args) throws Exception {List<String> list new ArrayList<S…

无处不在的智慧:探索嵌入式系统的奇妙

无处不在的智慧&#xff1a;探索嵌入式系统的奇妙 嵌入式系统作为当今科技领域中无处不在的一种技术&#xff0c;其奇妙之处正在逐步被揭示和探索。从智能家居到智能穿戴设备&#xff0c;从工业自动化到医疗健康&#xff0c;嵌入式系统已经深入到我们生活和工作的方方面面&…