#CF2200F. Mooclear Reactor 2

    ID: 7039 传统题 1000ms 256MiB 尝试: 2 已通过: 1 难度: 10 上传者: 标签>暴力数据结构贪心模拟排序CodeforcesCodeforces Round 1084(Div3)Div3FCF2200F1900

Mooclear Reactor 2

题目描述

Bessie 需要在她的“mooclear”反应堆中尽可能多地产生能量。她有 nn 种不同的粒子。

每个粒子由两个整数 xxyy 定义。该粒子可以产生 xx 单位的能量,但具有反应性 yy,意味着该粒子只能与至多 yy 个其它粒子一起存在于反应堆中。形式化来说,如果选择这个粒子来产生能量,那么最多只能再选择 yy 个其它粒子(不包括自身)参与产生能量。

Bessie 必须选择一些满足上述限制的粒子子集来产生能量。她所能产生的能量总量等于被选择粒子的能量之和。

有一个商店提供 mm 个粒子。Bessie 可以从商店中恰好购买一个粒子。对于商店里的每一个粒子,请你求出如果她只买这个粒子,那么她最多能产生的能量是多少。Bessie 并不要求一定要用上购买的粒子。

输入格式

第一行包含一个整数 tt1t1041 \leq t \leq 10^4),表示测试用例的数量。

每个测试用例的第一行包含两个整数 nnmm1n,m21051 \leq n, m \leq 2 \cdot 10^5),分别表示 Bessie 拥有的粒子数和商店中的粒子数。

接下来的 nn 行,每行包含两个整数 xxyy1x1091 \leq x \leq 10^90yn0 \leq y \leq n),分别表示 Bessie 的第 ii 个粒子的能量和反应性。

接下来的 mm 行,每行包含两个整数 xxyy1x1091 \leq x \leq 10^90yn0 \leq y \leq n),分别表示商店中第 jj 个粒子的能量和反应性。

保证所有测试用例中 nn 的总和以及 mm 的总和均不超过 21052 \cdot 10^5

输出格式

每组测试用例输出 mm 个整数,第 ii 个整数表示 Bessie 购买商店中第 ii 个粒子时,她所能产生的最大能量总和。

样例

3
3 3
67 0
6 1
7 1
1 0
100 0
62 1
2 1
2 2
4 2
3 1
1 2
6 1
7 0
8 1
67 100 69
7
7 14

样例说明

在第一个测试用例中:

  • 如果 Bessie 购买了粒子 44,最优策略是只用粒子 11 来产生 6767 单位的能量。
  • 如果她购买了粒子 55,则最佳选择是只用粒子 55,产生 100100 单位的能量。
  • 如果她购买了粒子 66,则应选择粒子 3366,合计产生 6969 单位的能量。

由 ChatGPT 5 翻译

来源

Codeforces 2200F,英文题名 Mooclear Reactor 2。