C. Messenger in MAC - 堆优化枚举

题面

分析

n n n的范围很小,可以 O ( n 2 ) O(n^2) O(n2)枚举,观察可以看出,选了几个数,他们的 b i b_i bi 计算总和的方法也就是将最左侧的 b i b_i bi到最右侧的 b i b_i bi 的距离,可以通过大根堆维护中途的最大数量,枚举左右端点。

代码
cpp 复制代码
#include <bits/stdc++.h>

using namespace std;
using ll = long long;

void solve() {
    int n;
    ll l;
    cin >> n >> l;
    vector<pair<ll, ll>> a(n + 1);
    for(int i = 1; i <= n; i ++) cin >> a[i].second >> a[i].first;
    sort(a.begin() + 1, a.end());
    int ans = 0;
    for(int i = 1; i <= n; i ++) {
        priority_queue<ll> heap;
        ll sum = 0;
        for(int j = i; j <= n; j ++) {
            heap.push(a[j].second);
            sum += a[j].second;
            while(heap.size() && a[j].first - a[i].first + sum > l) {
                ll maxn = heap.top();
                heap.pop();
                sum -= maxn;
            }
            ans = max(ans, (int)heap.size());
        }
    }
    cout << ans << "\n";
}

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);

    int T;
    cin >> T;
    while(T --) {
        solve();
    }
}
相关推荐
杜子不疼.2 小时前
【C++ AI 大模型接入 SDK】 - DeepSeek 模型接入(上)
开发语言·c++·chatgpt
石山代码3 小时前
C++ 内存分区 堆区
java·开发语言·c++
心中有国也有家3 小时前
cann-recipes-infer:昇腾 NPU 推理的“菜谱集合”
经验分享·笔记·学习·算法
绝知此事3 小时前
【算法突围 01】线性结构与哈希表:后端开发的收纳术
java·数据结构·算法·面试·jdk·散列表
碧海银沙音频科技研究院3 小时前
通话AEC与语音识别AEC的软硬回采链路
深度学习·算法·语音识别
csdn_aspnet4 小时前
Python 算法快闪 LeetCode 编号 70 - 爬楼梯
python·算法·leetcode·职场和发展
张小姐的猫5 小时前
【Linux】多线程 —— 线程互斥
linux·运维·服务器·c++
m0_629494737 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
壹号用户7 小时前
用队列实现栈
数据结构·算法