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();
    }
}
相关推荐
何曾参静谧27 分钟前
「C/C++」C/C++ 之 变量作用域详解
c语言·开发语言·c++
AI街潜水的八角36 分钟前
基于C++的决策树C4.5机器学习算法(不调包)
c++·算法·决策树·机器学习
白榆maple1 小时前
(蓝桥杯C/C++)——基础算法(下)
算法
JSU_曾是此间年少1 小时前
数据结构——线性表与链表
数据结构·c++·算法
此生只爱蛋2 小时前
【手撕排序2】快速排序
c语言·c++·算法·排序算法
何曾参静谧2 小时前
「C/C++」C/C++ 指针篇 之 指针运算
c语言·开发语言·c++
咕咕吖3 小时前
对称二叉树(力扣101)
算法·leetcode·职场和发展
九圣残炎3 小时前
【从零开始的LeetCode-算法】1456. 定长子串中元音的最大数目
java·算法·leetcode
lulu_gh_yu3 小时前
数据结构之排序补充
c语言·开发语言·数据结构·c++·学习·算法·排序算法
丫头,冲鸭!!!3 小时前
B树(B-Tree)和B+树(B+ Tree)
笔记·算法