luogu#P9113. [IOI2009] Hiring

[IOI2009] Hiring

题目背景

IOI2009 D1T2

题目描述

你需要为一个建设项目雇佣一些工人。现在有 NN 位候选工人,标号为 1N1\sim N。第 kk 个工人要求如果自己被雇佣,则必须得到至少 SkS_k 美元的工资。每个工人有能力值 QkQ_k。建筑业监管局规定,你必须按工人们的能力值的比例分配他们的工资。例如,如果 QA=3QBQ_A = 3Q_B,则你付给 AA 的工资必须恰为 BB 的三倍。你可以付给你的工人们任意非负实数金额的工资。

你的手上有 WW 美元,你想用这些钱雇佣最大数量的工人。你可以决定选用哪些工人以及付给他们的工资,但必须满足每个工人的最低工资要求以及监管局的分配规定,并保证工资总额不超过 WW

工人们的能力值和你的项目无关,因此你只想最大化雇佣工人的数量,而不关心他们的能力值。尽管如此,你仍希望最小化你的支出,即如果存在多种方案,则你需要选择支付给工人们的工资总额最小的那一个。如果仍存在多种方案,任意一个都是满足要求的。

任务:编写一个程序,给定每个工人的工资要求和能力值,以及你拥有的资金,计算出具体雇佣哪些工人。你必须在最大化工人的数量的前提下最小化支出,并满足上文提到的监管局的要求。

输入格式

第一行包含两个由空格隔开的整数 N,WN, W,分别表示候选工人数和你拥有的资金。

接下来 NN 行,每行描述一个候选工人。其中第 kk 行描述第 kk 个候选工人,包含两个由空格隔开的整数 Sk,QkS_k, Q_k

输出格式

第一行一个整数 HH,表示你雇佣的工人数量。

接下来 HH 行,每行一个整数,表示你雇佣的所有工人的编号(互不相同),以任意顺序排列。

4 100
5 1000
10 100
8 10
20 1

2
2
3

3 4
1 2
1 3
1 3

3
1
2
3

提示

样例解释

  • 样例 1:选择工人 2233 是唯一符合所有要求且雇佣了两个工人的方案。你可以分别付给他们 8080 美元和 88 美元,满足 100100 美元的预算。

  • 样例 2:你可以雇佣三个工人。你可以分别付给他们 11 美元,1.51.5 美元和 1.51.5 美元。

数据范围与约定

对于任意测试点,如果你的方案满足了所有要求和你的目标,你将获得该测试点的满分。否则,如果你的第一行是正确的,即你输出了正确的工人数量 HH,无论你接下来的输出是否符合格式,你都将获得该测试点 50%50\% 的分数。

注意,在实际评测中,只有你的输出符合格式,才能获得测试点 50%50\%100%100\% 的分数。

  • 对于 50%50\% 的数据,N5000N\leq 5000
  • 对于 100%100\% 的数据,1N5×1051\leq N\leq 5\times 10 ^ 51Sk,Qk2×1041\leq S_k, Q_k\leq 2\times 10 ^ 41W10101\leq W\leq 10 ^ {10}

注意,WW 超出了 3232 位整形变量的存储范围。你需要使用 6464 位整型变量存储 WW,例如 C/C++ 中的 long long 或 Pascal 中的 int64