蓝桥杯算法精讲:二分查找实战与变种解析

news2025/3/24 12:16:42

适合人群:蓝桥杯备考生 | 算法竞赛入门者 | 二分查找进阶学习者

目录

一、二分查找核心要点

1. 算法思想

2. 适用条件

3. 算法模板

二、蓝桥杯真题实战

例题1:分巧克力(蓝桥杯2017省赛)

例题2:砍竹子(蓝桥杯2022省赛)

三、二分查找变种与技巧

1. 查找左边界

2. 查找右边界

四、常见错误与注意事项

五、蓝桥杯进阶练习题


一、二分查找核心要点

1. 算法思想

二分查找(Binary Search)是一种在有序序列中快速定位目标的算法,通过不断缩小搜索范围,将时间复杂度从O(n)降至O(log n)。

2. 适用条件
  • 有序性:数据必须有序(升序或降序)

  • 单调性:问题的解空间具有单调性(如求最大值最小、最小值最大)

3. 算法模板
def binary_search(arr, target):  
    left, right = 0, len(arr) - 1  # 初始化左右指针  
    while left <= right:  
        mid = left + (right - left) // 2  # 防止整数溢出  
        if arr[mid] == target:  
            return mid  # 找到目标,返回索引  
        elif arr[mid] < target:  
            left = mid + 1  # 目标在右半部分  
        else:  
            right = mid - 1  # 目标在左半部分  
    return -1  # 未找到  

二、蓝桥杯真题实战

例题1:分巧克力(蓝桥杯2017省赛)

题目描述
有N块巧克力,每块大小为H[i]×W[i]。需切割出K块大小相同的正方形,求最大边长。

问题分析

  • 单调性:边长越大,能切出的块数越少

  • 二分目标:寻找满足块数≥K的最大边长

代码实现

def max_chocolate_size():  
    N, K = map(int, input().split())  
    H = []  
    W = []  
    for _ in range(N):  
        h, w = map(int, input().split())  
        H.append(h)  
        W.append(w)  

    # 二分范围:最小1,最大巧克力边长上限  
    left, right = 1, max(max(H), max(W))  
    ans = 0  
    while left <= right:  
        mid = (left + right) // 2  
        cnt = 0  # 当前边长能切出的总块数  
        for i in range(N):  
            cnt += (H[i] // mid) * (W[i] // mid)  
            if cnt >= K:  # 提前终止循环  
                break  
        if cnt >= K:  
            ans = mid  # 记录可行解  
            left = mid + 1  # 尝试更大的边长  
        else:  
            right = mid - 1  # 边长过大,缩小范围  
    return ans  

print(max_chocolate_size())  

代码解析

  1. 二分初始化:左边界为1,右边界取所有巧克力的最大边长

  2. 计算块数:对每块巧克力计算能切出的块数,累加直至超过K

  3. 调整边界:根据块数是否满足条件,动态调整左右边界

例题2:砍竹子(蓝桥杯2022省赛)

题目描述
给定N棵竹子的高度H[i],每次操作可选择一棵竹子砍到⌊√(H+1)⌋,求所有竹子砍到1的最少操作次数。

问题分析

  • 逆向思维:从1反向计算每个高度需要多少次操作到达

  • 预处理:对每个H[i],预计算其所有可能的中间值

代码实现

import math  

def min_operations():  
    N = int(input())  
    H = list(map(int, input().split()))  
    max_steps = 0  

    # 预处理每个竹子的操作链  
    for h in H:  
        steps = 0  
        current = h  
        while current > 1:  
            # 逆向计算:current由next_step通过f(x)=x^2-1得到  
            next_step = math.isqrt(current - 1) + 1  
            steps += 1  
            current = next_step  
        max_steps = max(max_steps, steps)  
    return max_steps  

print(min_operations())  

三、二分查找变种与技巧

1. 查找左边界

场景:数组中存在重复元素,找到第一个等于target的位置。

def left_bound(arr, target):  
    left, right = 0, len(arr) - 1  
    while left <= right:  
        mid = left + (right - left) // 2  
        if arr[mid] < target:  
            left = mid + 1  
        else:  
            right = mid - 1  # 压缩右边界  
    # 检查left是否越界或找到目标  
    return left if left < len(arr) and arr[left] == target else -1  
2. 查找右边界

场景:找到最后一个等于target的位置。

def right_bound(arr, target):  
    left, right = 0, len(arr) - 1  
    while left <= right:  
        mid = left + (right - left) // 2  
        if arr[mid] <= target:  
            left = mid + 1  # 压缩左边界  
        else:  
            right = mid - 1  
    # 检查right是否有效  
    return right if right >=0 and arr[right] == target else -1  

四、常见错误与注意事项

  1. 整数溢出:使用mid = left + (right - left) // 2而非(left + right)//2

  2. 边界更新:确保每次循环边界必然缩小,防止死循环

  3. 终止条件while left <= rightleft = mid + 1/right = mid -1配对使用

  4. 返回值验证:最终结果需检查是否有效(如索引是否越界)

五、蓝桥杯进阶练习题

  1. 数的范围(模板题):蓝桥杯题库

  2. 旋转数组的最小值(变种):蓝桥杯2021省赛

  3. 在排序数组中查找元素的第一个和最后一个位置:LeetCode 34

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

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

相关文章

C/C++转换为字符串宏和字符串拼接宏的综合使用

本文内容参考: C/C++ 宏拼接和宏展开为字符串 - DoubleLi - 博客园 特此致谢! 1. 转换为字符串宏与字符串拼接宏 (1)转换为字符串宏 转换为字符串的宏为: #define STR(x) #x //转字符串 (2)字符串拼接宏 字符串拼接的宏为: #define CONCAT(x,y) x##y //拼接 2…

掌握新编程语言的秘诀:利用 AI 快速上手 Python、Go、Java 和 Rust

网罗开发 &#xff08;小红书、快手、视频号同名&#xff09; 大家好&#xff0c;我是 展菲&#xff0c;目前在上市企业从事人工智能项目研发管理工作&#xff0c;平时热衷于分享各种编程领域的软硬技能知识以及前沿技术&#xff0c;包括iOS、前端、Harmony OS、Java、Python等…

个人常用的chrome好用插件

chrome可以说是兼容性和实用性较高的浏览器 没有复杂的ui 沉重的广告 加上各种各样的浏览器插件 现在罗列一下个人常用的几款好用的插件 1. Adblock Plus 一款免费的广告拦截器&#xff0c;可以拦截大部分网站上的广告推荐&#xff0c;还你一个干净舒服的页面 以下为b站演示…

数据库设计-笔记2

1.介绍一下MySQL 历史与发展 MySQL 最初由瑞典的 MySQL AB 公司开发&#xff0c;于 1995 年正式发布。2008 年&#xff0c;MySQL AB 公司被 Sun Microsystems 收购&#xff0c;之后 Sun 又被甲骨文&#xff08;Oracle&#xff09;公司收购&#xff0c;MySQL 成为 Oracle 旗下…

损失函数理解(二)——交叉熵损失

损失函数的目的是为了定量描述不同模型&#xff08;例如神经网络模型和人脑模型&#xff09;的差异。 交叉熵&#xff0c;顾名思义&#xff0c;与熵有关&#xff0c;先把模型换成熵这么一个数值&#xff0c;然后用这个数值比较不同模型之间的差异。 为什么要做这一步转换&…

基于随机森林回归预测葡萄酒质量

基于随机森林回归预测葡萄酒质量 1.作者介绍2.随机森林算法与数据集介绍2.1定义2.2核心思想2.3主要步骤2.4数据集介绍 3.算法实现3.1数据加载与探索3.2数据可视化3.3数据预处理&#xff08;标准化、划分训练/测试集&#xff09;3.4模型训练与优化&#xff08;随机森林回归 超参…

【Qt】QWidget属性2

&#x1f3e0;个人主页&#xff1a;Yui_ &#x1f351;操作环境&#xff1a;Qt Creator &#x1f680;所属专栏&#xff1a;Qt 文章目录 1. windowOpacity属性2. cursor属性2.1 自定义光标 3. font属性4.tooltip属性5. focusPolicy属性6. 总结 由于QWidget的常见属性实在太多&a…

OpenGL ES ->乒乓缓冲,计算只用两个帧缓冲对象(Frame Buffer Object)+叠加多个滤镜作用后的Bitmap

乒乓缓冲核心思想 不使用乒乓缓冲&#xff0c;如果要每个滤镜作用下的绘制内容&#xff0c;也就是这个滤镜作用下的帧缓冲&#xff0c;需要创建一个Frame Buffer Object加上对应的Frame Buffer Object Texture使用乒乓缓冲&#xff0c;只用两个Frame Buffer Object加上对应的F…

数据库练习2

目录 1.向heros表中新增一列信息&#xff0c;添加一些约束&#xff0c;并尝试查询一些信息 2.课堂代码练习 3.题目如下 一、单表查询 1、显示所有职工的基本信息。 2、查询所有职工所属部门的部门号&#xff0c;不显示重复的部门号。 3、求出所有职工的人数。 4…

macOS Sequoia 15.3 一直弹出“xx正在访问你的屏幕”

&#x1f645; 问题描述 macOS 系统升级后&#xff08;15.2或者15.3均出现过此问题&#xff09;&#xff0c;不管是截图还是开腾讯会议&#xff0c;只要跟捕捉屏幕有关&#xff0c;都一直弹出这个选项&#xff0c;而且所有软件我都允许访问屏幕了&#xff0c;这个不是询问是否…

C# 调用 VITS,推理模型 将文字转wav音频调试 -数字人分支

Microsoft.ML.OnnxRuntime.OnnxRuntimeException: [ErrorCode:InvalidArgument] Input name: input_name is not in the metadata在 Microsoft.ML.OnnxRuntime.InferenceSession.LookupInputMetadata(String nodeName) 位置 D:\a\_work\1\s\csharp\src\Microsoft.ML.OnnxRuntim…

【Docker系列一】Docker 简介

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

C++进阶——封装红黑树实现map和set

目录 1、源码及框架分析 2、模拟实现map和set 2.1 复用的红黑树框架及Insert 2.2 iterator的实现 2.2.1 iterator的核心源码 2.2.2 iterator的实现思路 2.3 map支持[ ] 2.4 map和set的代码实现 2.4.1 MyMap.h 2.4.2 MySet.h 2.4.3 RBTree.h 2.4.4 Test.cpp 1、源码及…

‘闭包‘, ‘装饰器‘及其应用场景

‘闭包’, 装饰器’及其应用场景 一, 闭包及其应用场景 图解 闭包的定义 概述: 内部函数 使用了 外部函数 的变量, 这种写法就称之为闭包. 格式: def 外部函数名(形参列表):外部函数的(局部)变量def 内部函数名(形参列表):内部函数的(局部)变量return 内部函数名前提条件: …

IDEA 快捷键ctrl+shift+f 无法全局搜索内容的问题及解决办法

本篇文章主要讲解IDEA、phpStrom、webStrom、pyCharm等jetbrains系列编辑器无法进行全局搜索内容问题的主要原因及解决办法。 日期&#xff1a;2025年3月22日 作者&#xff1a;任聪聪 现象描述&#xff1a; 1.按下ctrlshiftf 输入法转为了繁体。 2.快捷键ctrlshiftr 可以全局检…

Powershell WSL导出导入ubuntu22.04.5子系统

导出Linux子系统 导出位置在C盘下,根据自己的实际情况更改即可Write-Host "export ubuntu22.04.5" -ForegroundColor Green wsl --export Ubuntu-22.04 c:\Ubuntu-22.04.tar 导入Linux子系统 好处是目录可用在任意磁盘路径,便于迁移不同的设备之间Write-Host &quo…

论文笔记(七十三)Gemini Robotics: Bringing AI into the Physical World

Gemini Robotics: Bringing AI into the Physical World 文章概括1. 引言2. Gemini 2.0的具身推理2.1. 具身推理问答&#xff08;ERQA&#xff09;基准测试2.2. Gemini 2.0的具身推理能力2.3. Gemini 2.0支持零样本和少样本机器人控制 3. 使用 Gemini Robotics 执行机器人动作3…

AI + 医疗 Qwq大模型离线本地应用

通义千问Qwq-32b-FP16可用于社区医院、乡镇卫生院、诊所等小型医疗机构&#xff0c;替代专业合理用药系统&#xff0c;作为药品知识库&#xff0c;实现以下功能&#xff1a; 药品信息智能查询&#xff1a;检索药品的详细说明书、适应症、禁忌症、不良反应及药物相互作用等关键信…

元音辅音及其字母组合发音

文章目录 单元音长元音/ɑː//ɔ://u://i://ɜː/// 短元音/ʌ//ɒ//ʊ//ɪ//ə//e/ 双元音/eɪ//aɪ//ɔɪ//ɪə//eə//ʊə//əʊ//aʊ/ 辅音3个鼻辅音m n ŋ 5个独立浊辅音w j r l h 20个清浊相对的辅音s zʃ ʒf vθ p bt dk gts dztʃ dʒtr dr 以下是列举的部分字母组合…

【Vitis AIE】FPGA图像处理 11 双线性插值 Bilinear Interpolation

双线性插值 https://github.com/Xilinx/Vitis-Tutorials/tree/2024.2/AI_Engine_Development/AIE/Design_Tutorials/11-Bilinear_Interpolation 简介 双线性插值是一种使用重复线性插值来插值两个变量函数的方法。它通常用于以下应用&#xff1a; 图像处理和计算机视觉&…