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;
}
相关推荐
灵感__idea9 小时前
Hello 算法:众里寻她千“百度”
前端·javascript·算法
Wect19 小时前
LeetCode 130. 被围绕的区域:两种解法详解(BFS/DFS)
前端·算法·typescript
NAGNIP1 天前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
颜酱2 天前
单调栈:从模板到实战
javascript·后端·算法
CoovallyAIHub2 天前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
YOLO-IOD深度解析:打破实时增量目标检测的三重知识冲突
深度学习·算法·计算机视觉
NAGNIP2 天前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试