牛客每日一题(2026.4.30) 整数域二分

题目


AC代码

cpp 复制代码
#include<bits/stdc++.h> 
#define ll long long
using namespace std;

ll a[200005];

void solve()
{
    ll n,q;
    cin>>n>>q;
    for(ll i=1;i<=n;i++)
    {
        cin>>a[i];
    }
    sort(a+1,a+n+1);
    while(q--)
    {
        ll l,r;
        cin>>l>>r;

        if(l>r)
        {
            cout<<0<<endl;
            continue;
        }

        ll ans;
        ll lpos=0,rpos=n+1,mid;
        while(lpos+1!=rpos)
        {
            mid=lpos+(rpos-lpos>>1);

            if(a[mid]<l)lpos=mid;
            else rpos=mid;
        }
        ans=rpos;  // 左起点下标

        rpos=n+1;
        while(lpos+1!=rpos)
        {
            mid=lpos+(rpos-lpos>>1);
            
            if(a[mid]<=r)lpos=mid;
            else rpos=mid;
        }
        ans=lpos-ans+1;
        cout<<ans<<endl;
    }

}

int main()
{
    ios::sync_with_stdio(0);
    cin.tie(0);
    solve();
    return 0;
}

个人见解

今天的题相对于昨天还是比较简单的,主要就是考察二分的使用,模板题。

相关推荐
多看多敲多思考3 小时前
华润微CS32ME10 MCU使用教程(1)---CS32ME10之GPIO使用
c语言·stm32·单片机·嵌入式硬件·mcu
水蓝烟雨3 小时前
3335. 字符串转换后的长度 I
算法·leetcode
Dxy12393102163 小时前
HTML 如何使用 SVG 画曲线
前端·算法·html
westdata-Tm3 小时前
洛谷P1219 [USACO1.5] 八皇后 Checker Challenge
算法·深度优先·dfs
白夜11173 小时前
C++任务调度与状态机
开发语言·c++·笔记
南宫萧幕3 小时前
MATLAB/Simulink 从零打通:HEV 能量管理 GA 联合仿真保姆级建模指南
开发语言·算法·matlab·汽车·控制·pid
小雅痞4 小时前
[Java][Leetcode middle] 15. 三数之和
java·算法·leetcode
图码4 小时前
矩阵数据结构入门指南:声明、初始化与基本操作
运维·数据结构·线性代数·算法·矩阵
Navigator_Z4 小时前
LeetCode //C - 1030. Matrix Cells in Distance Order
c语言·算法·leetcode