【蓝桥】二分法

news/2025/2/21 8:18:55/

1、简介

1.1 定义:

通过将问题的搜索范围一分为二,迭代地缩小搜索范围,直到找到目标或确定目标不存在

1.2 适用:

有序数据集合,且每次迭代可以将搜索范围缩小一半

1.3 本质:

枚举:利用数据结构的单调性减少不必要的枚举,极大地提高了效率,一般可以优化到 O ( l o g n ) O(logn) O(logn)

1.4 常见类型:

1.4.1 整数二分

1.4.2 浮点二分

1.4.3 二分答案

2、解题步骤

  1. 研究并发现数据结构的单调性
  2. 确定最大区间[l, r],确保分界点一定在里面。
  3. 确定check函数,一般为传入mid(区间中某个下标),返回mid所属区域或返回一个值。
  4. 计算中点mid = (l + r) / 2,用check判断该移动lr指针(根据单调性及题目要求)。
  5. 返回lr(根据题目要求)。

3、整数二分

3.1 简介

  1. 定义:在一个已有的有序数组上,进行二分查找,一般为找出某个值的位置,或找出分界点
  2. 数组大小:一般为1e6

3.2 模板

#include <bits/stdc++.h>
using namespace std;int main(){int l = 0, r = 1e9;while(l + 1 != r){int mid = (l + r) / 2;if(a[mid] >= x) r = mid;else l = mid;}cout << r << '\n';return 0;
}

3.3 例题

3.3.1 题目描述

给定一个数组,其采用如下代码定义:

int data[200];
for(i = 0 ; i < 200 ; i ++) data[i] = 4 * i + 6;

现给定某个数,请你求出它在 data 数组中的位置(下标)。

3.3.2 输入描述

输入一个待查找的整数(该整数一定在数组 data 中)。

3.3.3 输出描述

输出该整数在数组中的指标。

3.3.4 输入输出样例

输入

262

输出

64

3.3.5 核心思路

  1. 数组初始化:创建一个大小为200的数组data,并根据公式4*i + 6初始化每个元素。
  2. 二分查找:使用二分查找算法高效地在排序数组中查找第一个大于或等于给定值n的元素的位置。
  3. 边界条件处理:虽然此代码未显式处理边界情况(如n小于数组最小值或大于数组最大值),但在实际应用中可能需要考虑这些情况。

3.3.6 代码

#include <iostream> // 导入输入输出流库,用于处理输入和输出
using namespace std;int main()
{int data[200];for(int i = 0 ; i < 200 ; i++) data[i] = 4 * i + 6;int n; // 定义一个整数n,用于存储用户输入的目标值cin >> n; // 从标准输入读取n的值int l = 0, r = 200; // 初始化二分查找的左右边界l和r,l为0,r为200(注意这里实际上是200而非199)// 使用二分查找算法在data数组中查找第一个大于或等于n的元素的位置while(l + 1 != r) { // 当l+1不等于r时继续循环,确保最终l和r相邻int mid = (l + r) / 2; // 计算中间位置midif(data[mid] >= n) // 如果中间位置的值大于或等于n,则缩小右边界r = mid;else // 否则,缩小左边界l = mid;}cout << r << '\n'; // 输出找到的位置rreturn 0;
}

4、浮点二分

4.1 简介

4.1.1 适用:

在某个实数范围内进行查找(因为实数域本身是单调的)

4.1.2 和整数二分的主要区别:

使用的变量类型、退出的判断条件

4.2 模板

// 计算单调函数f(x)的零点
double l = 0, r = 1e9, eps = 1e-6;
while(r - l >= eps){double mid = (l + r) / 2;if(f(mid) >= 0) r = mid;else l = mid;
}
cout << r << '\n';

5、二分答案

5.1 简介

5.1.1 常见模型

二分框架(时间复杂度O(logm)) + check函数(时间复杂度O(n))

5.1.2 用法

将答案进行二分,然后在枚举出某个可能解后判断其是否可以更优是否合法,从而不断逼近最优解

5.1.3 题目特征

如果已知某个答案,很容易判断其是否合法或更优(某些贪心问题也可以转化成二分答案)

5.2 模板

bool check(int mid){bool res = true;return res;
}int main(){int l = 0, r = 1e9;while(l + 1 != r){int mid = (l + r) / 2;if(check(mid)) l = mid;else r = mid;}cout << l << '\n';
}

微语录:我们风雨兼程而来,绝不空手而归。


http://www.ppmy.cn/news/1573833.html

相关文章

【GESP】C++二级真题 luogu-b3865, [GESP202309 二级] 小杨的 X 字矩阵

GESP二级真题&#xff0c;多层循环、分支语句练习&#xff0c;难度★✮☆☆☆。 题目题解详见&#xff1a;https://www.coderli.com/gesp-2-luogu-b3865/ 【GESP】C二级真题 luogu-b3865, [GESP202309 二级] 小杨的 X 字矩阵 | OneCoderGESP二级真题&#xff0c;多层循环、分…

【pytest】编写自动化测试用例命名规范README

API_autoTest 项目介绍 1. pytest命名规范 测试文件&#xff1a; 文件名需要以 test_ 开头或者以 _test.py 结尾。例如&#xff0c;test_login.py、user_management_test.py 这样的命名方式&#xff0c;pytest 能够自动识别并将其作为测试文件来执行其中的测试用例。 测试类…

Qt QStackedWidget 总结

Qt QStackedWidget 总结 概述 QStackedWidget 是 Qt 中的一个容器控件&#xff0c;用于管理多个子界面&#xff08;页面&#xff09;&#xff0c;但一次只显示一个。类似于标签页&#xff0c;但隐藏了切换标签的 UI&#xff0c;需手动控制页面切换逻辑。常用于向导界面、分步…

DeepSeek R1 与 OpenAI O1:机器学习模型的巅峰对决

我的个人主页 我的专栏&#xff1a;人工智能领域、java-数据结构、Javase、C语言&#xff0c;希望能帮助到大家&#xff01;&#xff01;&#xff01;点赞&#x1f44d;收藏❤ 一、引言 在机器学习的广袤天地中&#xff0c;大型语言模型&#xff08;LLM&#xff09;无疑是最…

Python基于Flask的豆瓣Top250电影数据可视化分析与评分预测系统(附源码,技术说明)

博主介绍&#xff1a;✌IT徐师兄、7年大厂程序员经历。全网粉丝15W、csdn博客专家、掘金/华为云//InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;&#x1f3…

TCP 三次握手与四次挥手:构建与终止可靠通信的核心机制

引言 TCP&#xff08;传输控制协议&#xff09;是网络通信的基石&#xff0c;其核心目标是&#xff1a; 在不可靠的IP层之上提供可靠的数据传输。 为实现这一目标&#xff0c;TCP通过 三次握手&#xff08;Three-way Handshake&#xff09;建立连接&#xff0c;通过四次挥手&am…

教育领域的AI革命:个性化学习导师的技术架构与未来展望 (八)

未来展望:教育元宇宙的雏形——重构人类认知边界的数字新大陆 一、技术基座:构建虚实共生的教育基础设施 神经界面革命脑机接口教育套件 斯坦福大学2024年推出的NeuroEdu头盔,通过128通道EEG阵列实现思维捕捉,学生可通过意念操控虚拟实验室设备,实验数据显示: 物理概念理…

Python----数据结构(栈:列表栈,链栈。初始化,入栈,出栈,获取栈长度,判断是否为空,访问栈顶元素)

一、栈 1.1、概念 栈&#xff08;stack)&#xff1a;又名堆栈&#xff0c;它是一种运算受限的线性表&#xff0c;是一种容器&#xff0c;可存入数据元素、访 问元素、删除元素&#xff0c;它的特点在于只能允许在容器的一端&#xff08;成为栈顶top&#xff09;&#xff0c;进…