题目描述
Peter 最近开始了一项兼职爱好——混合软饮料。他已经获得了对 N 种不同饮料类型的无限量供应权限。每种第 i 类饮料(0≤i<N)每升含有 Ai 克糖和 Bi 克酸。
Peter 正在家中举办一场聚会,并邀请了 Q 位最亲密的朋友。每位朋友都十分注重健康且颇为挑剔,并带着以下约束前来:
- MA:他们愿意摄入的糖的最大总重量(以克计)。
- MB:他们愿意摄入的酸的最大总重量(以克计)。
- LA,RA:他们只会饮用那些糖浓度(每升含糖克数)在 [LA,RA] 范围内(含两端)的饮料类型。
Peter 可以将不同数量的每种饮料(包括分数数量)混合,以调制定制化的无酒精鸡尾酒。形式化地,令 实数非负 的 Vi 表示在最终混合物中使用的第 i 种饮料的量(以升计)。则:
- 该无酒精鸡尾酒的总体积为 ∑i=0N−1Vi 升。
- 混合物中糖的总重量为 ∑i=0N−1Vi×Ai 克。
- 混合物中酸的总重量为 ∑i=0N−1Vi×Bi 克。
你的任务是帮助 Peter 确定他能为每位朋友提供的 最大总体积(以升计),同时满足他们各自的约束。
实现细节
你需要实现如 soft_drinks.h 中所定义的以下函数:
void init(const std::vector<int>& A, const std::vector<int>& B);
init 函数将在任何其他查询之前被恰好调用一次。其参数对应如下:
- A:一个长度为 N 的向量,其中 A[i] 是第 i 种饮料每升的含糖量。
- B:一个长度为 N 的向量,其中 B[i] 是第 i 种饮料每升的含酸量。
double friendDrink(int Ma, int Mb, int La, int Ra);
friendDrink 函数会为 Q 位朋友中的每一位各调用一次。其参数对应如下:
- Ma:该朋友将摄入的糖的最大总重量。
- Mb:该朋友将摄入的酸的最大总重量。
- La,Ra:该朋友愿意接受饮用的饮料类型的糖浓度所在闭区间边界。
该函数应返回一个 double,表示 Peter 可以在不违反该朋友任何约束的情况下为其提供的最大体积(以升计)。
如果你的答案的绝对误差或相对误差不超过 10−6,则被视为正确。即,若你的答案为 a,正确答案为 b,则当 max(1,∣b∣)∣a−b∣≤10−6 时,你的答案会被接受。
本地测试
提供了一个本地评测器 Lgrader.cpp 以及相应的头文件 soft_drinks.h。
输入格式
输入格式:
- 第一行:整数 N 和 Q。
- 接下来的 N 行:每行两个整数 Ai 和 Bi,描述每种饮料。
- 接下来的 Q 行:每行四个整数 MA, MB, LA 和 RA,描述每位朋友。
评测器将调用 init,随后为每位朋友调用 friendDrink,并将结果打印至标准输出。
4 3
4 0
2 8
6 4
3 6
8 2 4 6
8 2 3 6
0 10 0 10
2
2.0833333
0
提示
数据范围
- 1≤N,Q≤105
- 0≤Ai,Bi,MA,MB,LA,RA≤109
- 要么 Ai=0 要么 Bi=0。
子任务
| 子任务 |
分值 |
N |
Q |
附加约束 |
| 0 |
−− |
样例测试 |
| 1 |
6 |
≤2 |
≤100 |
−− |
| 2 |
9 |
≤105 |
MA=MB |
| 3 |
7 |
MA=0, Ai=0 |
| 4 |
9 |
≤500 |
−− |
| 5 |
15 |
≤5000 |
| 6 |
7 |
≤105 |
≤1000 |
(LA,RA)=(0,109) |
| 7 |
18 |
≤105 |
| 8 |
29 |
−− |
只有在成功通过某子任务的所有测试及其所包含的所有其他子任务的测试后,才能获得该子任务的分数。
翻译由 DeepSeek V4 Pro 完成