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;
}
相关推荐
吃着火锅x唱着歌2 小时前
LeetCode 1963 使字符串平衡的最小交换次数
算法·leetcode·职场和发展
无敌昊哥战神2 小时前
【算法与数据结构】深入浅出回溯算法:理论基础与核心模板(C/C++与Python三语解析)
c语言·数据结构·c++·笔记·python·算法
輕華2 小时前
OpenCV三大传统人脸识别算法:EigenFace、FisherFace与LBPH实战
人工智能·opencv·算法
akarinnnn2 小时前
【DAY16】字符函数和字符串函数
c语言·数据结构·算法
_日拱一卒2 小时前
LeetCode:螺旋矩阵
算法·leetcode·矩阵
Tairitsu_H2 小时前
C语言:排序(二)
c语言·开发语言·算法
Q741_1473 小时前
每日一题 力扣 1848. 到目标元素的最小距离 模拟 C++题解
c++·算法·leetcode·模拟
VkN2X2X4b4 小时前
算法性能的渐近与非渐近行为对比的技术9
算法
好家伙VCC4 小时前
**神经编码新视角:用Python实现生物启发的神经信号压缩与解码算法**在人工智能飞速发展的今天
java·人工智能·python·算法
W230357657311 小时前
经典算法:最长上升子序列(LIS)深度解析 C++ 实现
开发语言·c++·算法