hh的蓝桥杯每日一题

P9426 蓝桥杯 2023 国 B 抓娃娃 - 洛谷

这个题目用了二分的方法去优化时间复杂度

首先根据题目可以得到的是--线段中点在区间内才算是被区间覆盖

线段中点在线段内 ⇔ L ≤ (l+r)/2 ≤ R

然后可以转化为2L ≤ l+r ≤ 2R

cpp 复制代码
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;

const int N = 100010;

int mid2[N];  // 存储每个线段中点的2倍值
int n, m;

// 找到第一个 >= x 的位置
int find_left(int x) {
    int l = 0, r = n - 1;
    while (l <= r) {
        int mid = (l + r) / 2;
        if (mid2[mid] >= x) {
            r = mid - 1;
        } else {
            l = mid + 1;
        }
    }
    return l;  // l是第一个>=x的位置
}

// 找到第一个 > x 的位置
int find_right(int x) {
    int l = 0, r = n - 1;
    while (l <= r) {
        int mid = (l + r) / 2;
        if (mid2[mid] > x) {
            r = mid - 1;
        } else {
            l = mid + 1;
        }
    }
    return l;  // l是第一个>x的位置
}

int main() {
    cin >> n >> m;
    
    for(int i = 0; i < n; i++) {
        int l, r;
        cin >> l >> r;
        mid2[i] = l + r;  // 中点的2倍
    }
    
    // 排序
    sort(mid2, mid2 + n);
    
    // 处理m个查询
    for(int k = 0; k < m; k++) {
        int L, R;
        cin >> L >> R;
        
        // 自己实现二分查找
        int left = find_left(2 * L);    // 第一个 >= 2L 的位置
        int right = find_right(2 * R);  // 第一个 > 2R 的位置
        
        cout << (right - left) << endl;
    }
    
    return 0;
}
相关推荐
QiLinkOS6 分钟前
第三视觉理解徐玉生与他的商业活动(28)
大数据·c++·人工智能·算法·开源协议
码云数智-大飞35 分钟前
从 OC 平滑迁移 Swift 完整方案
职场和发展·蓝桥杯
wabs66640 分钟前
关于动态规划【力扣1143.最长公共子序列的思考】
算法·leetcode·动态规划
剑挑星河月1 小时前
54.螺旋矩阵
java·算法·leetcode·矩阵
Robot_Nav1 小时前
MPPI 局部规划器实验设计讲解
人工智能·算法·mppi
mingo_敏2 小时前
Mean-Teacher 均值教师自训练框架详解
算法·均值算法
水木流年追梦2 小时前
agent面试必备31- AI Agent 核心进阶:工具路由(Tool Routing)
数据库·人工智能·oracle·面试·职场和发展·embedding
星空露珠2 小时前
迷你世界UGc3.0脚本Wiki[剧情动画模块管理接口 Timeline]
开发语言·数据结构·算法·游戏·lua
笨笨没好名字2 小时前
Leetcode刷题python3版第一周(下)
linux·算法·leetcode
手写码匠3 小时前
手写 LLM 安全护栏:从内容审核到越狱防御的完整实现
人工智能·深度学习·算法·aigc