CFCF2174B.Wishing Cards
普及+/提高
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
据说在除夕夜写下心愿卡能带来好运。你已经写好了心愿卡,打算送给 Little A。
你邀请了 n 位朋友帮你送心愿卡。你计划让第 i 位朋友带 bi 张心愿卡。朋友们将依次以 1 到 n 的顺序拜访 Little A,每个人会把自己全部的 bi 张心愿卡交给 Little A。Little A 会记住送她心愿卡最多的那位朋友,所以在第 j 位朋友拜访之后,她会获得等于当前收到的最多卡片数量的幸福值,即 max(b1,b2,…,bj)。
第 i 位朋友最多能携带 ai 张卡片,并且总共送出的卡片数不能超过 k。你的任务是在以上约束下,最优地选择每个人带卡片的数量 bi,使得 n 次拜访后 Little A 获得的总幸福值最大。
注意,有些朋友可以一张卡片也不带,Little A 并不会因此生气。
输入格式
每组测试包含多个测试用例。第一行包含测试用例数量 t(1≤t≤103)。接下来是每组测试用例的描述。
每个测试用例的第一行包含两个整数 n 和 k(1≤n≤105,1≤k≤360),分别表示朋友的数量和最大能送出的心愿卡总数。
第二行包含 n 个整数 a1,a2,…,an(0≤ai≤k),分别表示每个朋友最多能携带的卡片数。
保证所有测试用例中的 n 总和不超过 5×105,所有测试用例中的 k 总和不超过 1800。
输出格式
对于每个测试用例,输出 Little A 能获得的最大幸福值。
输入输出样例
输入#1
4 3 4 0 0 1 6 8 1 2 0 5 1 8 3 4 1 0 4 5 8 2 4 5 4 3
输出#1
1 20 5 19
说明/提示
在第一个测试用例中,唯一的分配方式是 b=[0,0,1]。
在第三个测试用例中,b=[1,0,4] 不合法,因为你只有 k=4 张心愿卡。
在第四个测试用例中,一种最优分配方式是 b=[2,0,5,0,0],这样 Little A 会获得 2+2+5+5+5=19 的幸福值。