欢迎来到起遇信息学
起遇信息学正处于上线筹建阶段,以下功能已全部开放免费体验: ✅ 完整题库浏览与代码提交评测(C / C++ / Python / Java 等) ✅ 入门到进阶的系列课程试读、作业与考试 ✅ AI 提示、AI 作业分析等智能助教功能 ✅ 赛事模拟与个人能力报告 ✅ 邮箱注册开放 ⏳ 付费课程订阅与微信/支付宝支付通道 ⏳ 手机号登录,微信扫码登录、微信公众号绑定 使用中如遇任何问题,欢迎通过页面底部 **"联系我们"** 与我们沟通。
CF2143B.Discounts
Discounts
题目描述
你打算购买 个商品,价格分别为 。你可以选择以下两种方式购买每件商品:
- 逐个购买商品 ,需支付 个硬币;
- 使用一张折扣券,将其作为团购的一部分购买。
你有 张面值分别为 的折扣券。面值为 的折扣券可以让你选中恰好 个商品,并且只需支付其中价格最高的 个商品,价格最低的那一个免费。你可以将其理解为团购中最便宜的一件商品免费。
每个商品最多只能被纳入一个折扣团购组,无论它是否是免费那件。同一张折扣券最多只能用一次。
请你计算,购买所有 个商品的最小总花费是多少。
输入格式
输入包含多组测试数据。第一行包含一个整数 (),表示测试用例的数量。
每个测试用例的第一行包含两个整数 和 (),分别表示商品数和折扣券数。
第二行包含 个整数 (),表示每件商品的价格。
第三行包含 个整数 (),表示每张折扣券的面值。
保证所有测试用例中 的总和不超过 , 的总和也不超过 。
输出格式
输出 行,第 行表示第 个测试用例购买所有商品所需的最小总花费。
说明/提示
在第一个测试用例中,你可以把第一张折扣券用在第 2、3、4 号商品上,需支付价格最高的 2 件(3 和 7 个硬币),最便宜的那件免费,总共花费 个硬币。然后用第 2、第 3 张折扣券买第 1、5 件商品,使它们都免费。总费用为 。
在第二个测试用例中,可以用那张面值为 5 的折扣券,团购第 2、3、4、5、6 件商品,其中最便宜的是第 2 件(2 个硬币),免费。其余需支付 个硬币。
在第三个测试用例中,只有一张折扣券,可以团购两件商品,免费最便宜的那一件,需支付 个硬币。
由 ChatGPT 5 翻译
样例
5
5 3
18 3 7 2 9
3 1 1
6 1
1 2 6 3 3 4
5
2 3
1 1
2 2 2
1 1
10
1
5 3
99 99 999 999 123
2 1 4
10
17
1
0
1197
在线编程 IDE
建议全屏模式获得最佳体验
| 进入全屏编程 | Alt+E |
| 递交评测 | Ctrl+Enter |
| 注释/取消注释 | Ctrl+/ |
| 缩放字体 | Ctrl+滚轮 |