首页 > 编程语言 >二分算法查找模板

二分算法查找模板

时间:2023-01-16 11:55:05浏览次数:70  
标签:二分 return int mid 查找 check 模板

这个是acwing站长YXC的模板
https://www.acwing.com/file_system/file/content/whole/index/content/3073/

版本1
当我们将区间[l, r]划分成[l, mid]和[mid + 1, r]时,其更新操作是r = mid或者l = mid + 1;,计算mid时不需要加1。

C++ 代码模板:
int bsearch_1(int l, int r)
{
    while (l < r)
    {
        int mid = l + r >> 1;
        if (check(mid)) r = mid;
        else l = mid + 1;
    }
    return l;
}
版本2
当我们将区间[l, r]划分成[l, mid - 1]和[mid, r]时,其更新操作是r = mid - 1或者l = mid;,此时为了防止死循环,计算mid时需要加1。

C++ 代码模板:
int bsearch_2(int l, int r)
{
    while (l < r)
    {
        int mid = l + r + 1 >> 1;
        if (check(mid)) l = mid;
        else r = mid - 1;
    }
    return l;
}

这个是《算法竞赛进阶指南》的模板 对于check函数也进行了描述

保证答案处于闭区间[l,r]以内,循环以l=r结束
在单调递增序列a中查找>=x的数中最小的一个(即x或x的后继)
while(l<r){
  int mid = l+r>>1;
  if(a[mid]>=x) r=mid;else l = mid+1;
}
return a[l];

在单调递增序列a中查找<=x的数中最大一个(即x或者x的前驱)
while(l<r){
  int mid = (l+r+1)>>1;
  if(a[mid]<=x) l= mid;else r =mid-1;
}
return a[l];

我的视频题解空间

标签:二分,return,int,mid,查找,check,模板
From: https://www.cnblogs.com/itdef/p/17055089.html

相关文章

  • 2023.1.16[模板]BSGS/exBSGS
    2023.1.16[模板]BSGS/exBSGS全称BoyStepGirlStep给定一个质数p,以及一个整数a,一个整数b,现在要求你计算一个最小的非负整数l,满足\(a^x\equivb(modp)\)算法......
  • border树模板
    P5829【模板】失配树关键这里的前缀和后缀是不能包含自己的,其他就是板子代码#include<bits/stdc++.h>usingnamespacestd;constintM=1e6+5;chars[M];intne......
  • effective modern c++ - 1 理解模板类别推导
    模板中的行参类型推断会省略引用在这两种模板中,行参的引用都会在推断过程中被省略template<typenameT>//templateAvoidf(T&param);template<typenameT>//temp......
  • 模板-mod类
    模板intMOD;//constintMOD=;structModInt{intx;ModInt(intx=0):x(x%MOD){}ModInt(longlongx):x(x%MOD){}intval(){......
  • 常用算法模板
    BFS单向BFS不记录层数whilequeue不空:cur=queue.pop()for节点incur的所有相邻节点:if该节点有效且未访问过:queue.push(该节点)......
  • 【数据结构与算法】二分查找算法(C++实现)
    两种写法,取决于划分规则。这两种写法是学的yxc的,至此以后,写二分查找再也不含糊了!yxc的分享在此:二分查找算法模板第一种写法:boolbinarySearch(vector<int>&nums,int......
  • P1886 滑动窗口 /【模板】单调队列
    滑动窗口/【模板】单调队列题目描述有一个长为\(n\)的序列\(a\),以及一个大小为\(k\)的窗口。现在这个从左边开始向右滑动,每次滑动一个单位,求出每次滑动后窗口中的......
  • 在 Linux 上查找特定文件的所有链接
    概述在本教程中,我们将学习如何在Linux上查找特定文件的所有链接。我们将使用命令lsof列出任何进程打开的所有文件,然后grep仅过滤掉那些链接到目标文件的文件。什么是......
  • 二分
    概述二分查找二分答案核心思路:把求解性问题变成naive的判定性问题。相当于是支付复杂度换可做性。分数规划考虑化式子,对于\(mid\),有\[\begin{aligned}&\dfr......
  • 【LeeCode】704. 二分查找
    【题目描述】给定一个 ​​n​​ 个元素有序的(升序)整型数组 ​​nums​​ 和一个目标值 ​​target​​  ,写一个函数搜索 ​​nums​​ 中的 ​​target​​,如果......