备战蓝桥杯:二分算法之牛可乐和魔法封印问题

这道题就是一道简单的模板题,我们分析一下!,首先我们要找大于等于x的起始位置

我们还是用两个指针,left指向1,right指向n,如果a[mid]<x left = mid+1

如果a[mid]>=x 就让right= mid

如果数组全是小于x的话,x = 3 ,[0 , 1 , 2] 我们最后就会指向2,2还是小于x的,所以我们这个数组大于等于x的值不存在,返回0

接下来我们找一下小于等于y的终止位置

如果a[mid]大于y,right=mid-1,

如果a[mid]小于等于y,left=mid+1

我们还需要考虑一下最后结果可能是大于y的情况,比如y是3,数组是[4,5,6]的话,结果是4,4还是大于3的,根本就找不到小于等于3的区间,所以返回0

好的,话不多说我们写一下代码

cpp 复制代码
#include <iostream>
using namespace std;
const int N = 1e5 + 10;
int n;
int a[N];
int binary_search(int x1, int x2)
{
    int left = 1, right = n;
    while (left < right)
    {
        int mid = (left + right) / 2;
        if (a[mid] >= x1) right = mid;
        else left = mid + 1;
    }
    if (a[left] < x1) return 0;
    int tmp = left;
    left = 1, right = n;
    while (left < right)
    {
        int mid = (left + right + 1) / 2;
        if (a[mid] <= x2) left = mid;
        else right = mid - 1;
    }
    if(a[left]>x2) return 0;
    return left - tmp + 1;
}
int x, y;
int main()
{
    cin >> n;
    for (int i = 1; i <= n; i++) cin >> a[i];
    int q; cin >> q;
    while (q--)
    {
        cin >> x >> y;
        cout << binary_search(x, y) << endl;
    }
}
相关推荐
Fly Wine2 小时前
Leetcode之有效字母异位词
算法·leetcode·职场和发展
程序员夏末4 小时前
【LeetCode | 第七篇】算法笔记
笔记·算法·leetcode
csdn_aspnet4 小时前
C/C++ 两个凸多边形之间的切线(Tangents between two Convex Polygons)
c语言·c++·算法
数据皮皮侠5 小时前
中国城市间地理距离矩阵(2024)
大数据·数据库·人工智能·算法·制造
3GPP仿真实验室5 小时前
深度解析基站接收机核心算法:从 MRC 到 IRC 的空间滤波演进
算法
Boop_wu5 小时前
[Java 算法] 动态规划(1)
算法·动态规划
WolfGang0073215 小时前
代码随想录算法训练营 Day18 | 二叉树 part08
算法
hanlin036 小时前
刷题笔记:力扣第43、67题(字符串计算)
笔记·算法·leetcode
yang_B6216 小时前
最小二乘法 拟合平面
算法·平面·最小二乘法
放下华子我只抽RuiKe56 小时前
深度学习全景指南:硬核实战版
人工智能·深度学习·神经网络·算法·机器学习·自然语言处理·数据挖掘