#P15812. [JOI 2014 Final] IOI 饅頭

    ID: 15750 远端评测题 1000ms 256MiB 尝试: 0 已通过: 0 难度: 5 上传者: 标签>动态规划 DP贪心2014排序背包 DPJOI(日本)

[JOI 2014 Final] IOI 饅頭

说明

Incredible Okashi Inc. 是一家制作“不可思议的美味点心 (incredible okashi)”的公司。以下简称 IOI 社。IOI 社 制作了特制的 IOI 馒头,并决定将其出售。IOI 社 制作了 MM 种馒头,每种一个。制作出的 MM 个馒头大小相同,但味道各异,因此价格各不相同,第 ii 个 (1iM1 \le i \le M) 馒头的价格为 PiP_i 日元。

话说回来,你知道 Just Odd Inventions 公司吗?这家公司的业务是进行“仅仅是奇妙的发明 (just odd inventions)”。以下简称 JOI 社。IOI 社决定向 JOI 社订购用于装馒头的豪华盒子。JOI 社 制作的馒头用盒子有 NN 种,第 jj 种 (1jN1 \le j \le N) 盒子最多能装 CjC_j 个馒头,其售价为 EjE_j 日元。IOI 社决定订购这 NN 种盒子中的若干种(0 种以上 NN 种以下),每种一个,然后将馒头分装到这些盒子里作为套装出售。每个馒头套装的价格等于其中所装馒头价格的总和。

假设所有馒头套装都能售出,IOI 社能够获得的最大利润是多少?这里利润是指售出的所有馒头套装价格总和减去订购的所有盒子价格总和。另外,对于没有装入盒子的馒头,将由 IOI 社的员工美味地享用,因此不影响利润。

任务

给定每个馒头的价格,以及每种盒子的容量和价格,编写程序求出 IOI 社能够获得的最大利润。

输入格式

从标准输入读取以下数据。

  • 第 1 行包含以空格分隔的整数 M,NM, N,表示有 MM 个馒头和 NN 种盒子。
  • 接下来 MM 行中的第 ii 行 (1iM1 \le i \le M) 包含整数 PiP_i,表示第 ii 个馒头的价格为 PiP_i 日元。
  • 接下来 NN 行中的第 jj 行 (1jN1 \le j \le N) 包含以空格分隔的整数 Cj,EjC_j, E_j,表示第 jj 种盒子最多能装 CjC_j 个馒头,其价格为 EjE_j 日元。

输出格式

向标准输出输出一行,包含一个整数,表示 IOI 社能获得的最大利润(单位:日元)。

4 3
180
160
170
190
2 100
3 120
4 250
480
2 2
1000
2000
1 6666
1 7777
0
10 4
200
250
300
300
350
400
500
300
250
200
3 1400
2 500
2 600
1 900
450

提示

样例解释 1

在此样例中,订购第 1 种盒子(100100 日元)和第 2 种盒子 (120120 日元)。例如,将第 1 个和第 2 个馒头装入第 1 个盒子,作为 180+160=340180 + 160 = 340 日元的套装出售;将第 3 个和第 4 个馒头装入第 2 个盒子,作为 170+190=360170 + 190 = 360 日元的套装出售。则 IOI 社的利润为 700220=480700 - 220 = 480 日元。

样例解释 2

在此样例中,为了最大化利润,最好完全不购买任何盒子。

数据范围

所有输入数据满足以下条件。

  • 1M100001 \le M \le 10000
  • 1N5001 \le N \le 500
  • 1Pi100001 \le P_i \le 10000 (1iM1 \le i \le M)
  • 1Cj100001 \le C_j \le 10000 (1jN1 \le j \le N)
  • 1Ej100001 \le E_j \le 10000 (1jN1 \le j \le N)

子任务

子任务 1 [25 分]

满足 N10N \le 10

子任务 2 [35 分]

满足 Cj10C_j \le 10 (1jN1 \le j \le N)。

子任务 3 [40 分]

没有额外限制。


翻译由 DeepSeek V3.2 完成