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();
    }
}
相关推荐
workflower8 分钟前
使用谱聚类将相似度矩阵分为2类
人工智能·深度学习·算法·机器学习·设计模式·软件工程·软件需求
☆平常心☆9 分钟前
UE5通过C++实现TcpSocket连接
c++·ue5
cwywsx18 分钟前
Linux:进程控制2
linux·运维·算法
真的想上岸啊33 分钟前
c语言第一个小游戏:贪吃蛇小游戏06
c语言·算法·链表
边跑边掩护39 分钟前
LeetCode 648 单词替换题解
算法·leetcode·职场和发展
dot to one1 小时前
Qt 中 QWidget涉及的常用核心属性介绍
开发语言·c++·qt
小森77671 小时前
(七)深度学习---神经网络原理与实现
人工智能·深度学习·神经网络·算法
二年级程序员1 小时前
C++的历史与发展
c++
迷茫不知归路2 小时前
操作系统实验习题解析 上篇
c++·算法·操作系统·实验课设
一个尚在学习的计算机小白2 小时前
文件相关操作
c++