传送门

•参考资料

  [1]:2019CCPC网络选拔赛 H.Fishing Master(思维+贪心)

•题意

  池塘里有 n 条鱼,捕捉一条鱼需要花费固定的 k 时间;

  你有一个锅,每次只能煮一条鱼,其中煮熟第 i 条鱼至少需要 ti 时间;

  你在煮鱼的时候可以选择去钓一条鱼,也可也选择不钓;

  但是,一旦你决定钓鱼,就必须花费 k 时间调到一条鱼;

  任何时刻,你都可以有多条鱼待煮;

  问将所有的鱼钓上来并煮熟所有的鱼最少需要多少时间;

•题解

  理想的方案是只有在钓第一条鱼的时候锅是空的,其余任意时刻,锅都在做有用功;

  锅在做有用功指的是第 i 条鱼在锅中煮的前 ti 时间,多煮的时间称锅在做无用功;

  这种情况下,只需要且必须花费 $k+\sum_{i=1}^{n}t_i$ 时间就可以将所有鱼全部钓上来并全部煮好;

  那么,实际情况并非如此,要想花费最少的时间,首先得明确在什么情况下可能会导致时间浪费;

  假设你当前煮的鱼需要花费 t 时间,钓鱼需要花费 k 时间;

  你可以在这 t 时间内钓 $\frac{t}{k}$ 条鱼上来,在钓鱼的时间,锅处于煮鱼状态;

  但是剩下的 t%k 时间不足以再钓一条上来;

  此时,你就有两个决策可以选择:

    决策1:去钓下一条鱼;

    决策2:等待 t%k 时间往锅中放入下一条鱼;

  当然,选择 决策2 的前题是你得有鱼可煮;

  如果你手中有鱼的话,肯定要选择 决策2,因为等待的这 t%k 时间是必须的;

  而如果选择 决策1,那么煮当前这条鱼会花费 t+k-t%k 时间,前 t 时间锅在做有用功,是必须的;

  但是后 k-t%k 时间,锅就在做无用功,是在浪费时间;

  如果你当前手中无鱼,那么你不得不去钓鱼,那么就一定要浪费当前的 k-t%k 时间么?

  假设你现在已经煮了 i 条鱼(包括当前煮的这条鱼);

  那么,你完全可以在前 i 条鱼中找个 tj%k($j \in [1,i]$)大的从而使得浪费的 k-tj%k 时间尽可能的小;

  找 tj%k 大的就可以使用优先级队列了;

  那么,接下来就要分析一下优先钓哪条鱼了;

  当然是优先钓煮的时间较长的鱼了,因为在煮这条鱼的时候,你会尽可能多的钓上来其他的鱼,从尽可能多的选择决策2;

•Code

 #include<bits/stdc++.h>
using namespace std;
#define ll long long
const int maxn=1e5+; int n,k;
int t[maxn];
priority_queue<int >q; bool cmp(int a,int b)
{
return a > b;
}
ll Solve()
{
while(!q.empty())
q.pop(); /**
花费k时间钓上来第一条鱼
*/
ll ans=k;
ll cnt=;
sort(t+,t+n+,cmp); for(int i=;i <= n;++i)
{
ans += t[i];///煮第i条鱼
cnt += t[i]/k;///再煮的时间可以额外钓t[i]/k条 if(cnt < i)///如果在煮第i条鱼的时候并没有将第i条鱼钓上来
{
ans += k-q.top();///选择在t%k最大的那条鱼后钓第i条鱼
q.pop();
}
q.push(t[i]%k);
}
return ans;
}
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&n,&k);
for(int i=;i <= n;++i)
scanf("%d",t+i); printf("%lld\n",Solve());
}
return ;
}

HDU 6709“Fishing Master”(贪心+优先级队列)的更多相关文章

  1. HDU 6438"Buy and Resell"(贪心+优先级队列)

    传送门 •参考资料 [1]:HDU6438(优先队列+思维) •题意 有n个城市,第 i 天你会达到第 i 个城市: 在第 i 个城市中,你可以用 ai 元购买一个物品,或者用 ai 元卖掉一个物品, ...

  2. The 10th Shandong Provincial Collegiate Programming Contest H.Tokens on the Segments(贪心+优先级队列 or 贪心+暴力)

    传送门 •题意 二维平面上有 n 条线段,每条线段坐标为 $(l_i,i),(r_i,i)$: 平面上的每个整点坐标上都可以放置一枚硬币,但是要求任意两枚硬币的横坐标不相同: 问最多有多少条线段可以放 ...

  3. POJ 3253 Fence Repair 贪心 优先级队列

    Fence Repair Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 77001   Accepted: 25185 De ...

  4. POJ 2431 Expedition 贪心 优先级队列

    Expedition Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 30702   Accepted: 8457 Descr ...

  5. 【Fishing Master HDU - 6709 】【贪心】

    题意分析 题意:题目给出n条鱼,以及捕一条鱼所用的时间k,并给出煮每一条鱼的时间,问抓完并煮完所有鱼的最短时间. 附题目链接 思路: 1.捕第一条鱼的时间是不可避免的,煮每条鱼的时间也是不可避免的,这 ...

  6. hdu 1873 看病要排队(优先级队列)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1873 题目大意: 三个医生看病,病人排队看病,病人有优先级,优先级高的提前看病,同样的优先级按先后.I ...

  7. HDU 6047 Maximum Sequence (贪心+单调队列)

    题意:给定一个序列,让你构造出一个序列,满足条件,且最大.条件是 选取一个ai <= max{a[b[j], j]-j} 析:贪心,贪心策略就是先尽量产生大的,所以就是对于B序列尽量从头开始,由 ...

  8. 【POJ 3614 Sunscreen】贪心 优先级队列

    题目链接:http://poj.org/problem?id=3614 题意:C头牛去晒太阳,每头牛有自己所限定的spf安全范围[min, max]:有L瓶防晒液,每瓶有自己的spf值和容量(能供几头 ...

  9. [贪心,dp] 2019中国大学生程序设计竞赛(CCPC) - 网络选拔赛 Fishing Master (Problem - 6709)

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=6709 Fishing Master Time Limit: 2000/1000 MS (Java/Othe ...

随机推荐

  1. Pyhton AES_cbc解密

    最近很多朋友问我加密解密有没有啥好推荐的方式,一般对AES的加密解密方式直接用在线加密或者解密就行,我为了方便测试,将网址以python脚本的形式写了出来,很简单的东西,2分钟搞定,随手记录一下~~ ...

  2. php is_null、empty、isset的区别

    isset 判断变量是否已存在 empty 判断变量是否为空或为0 is_null 判断变量是否为NULL 变量 empty is_null isset $a=”” true false true $ ...

  3. 2018-8-10-C#-快速释放内存的大数组

    title author date CreateTime categories C# 快速释放内存的大数组 lindexi 2018-08-10 19:16:52 +0800 2018-2-13 17 ...

  4. Linux 上GCC的静态编译和动态编译

    静态编译 常规编译示例: $gcc xxx.c yyy.c zzz.c -o rslt 注明: gcc编译器会对源文件min.c进行预处理, 编译, 以及链接, 最后生成可执行文件 $gcc -c x ...

  5. SpringMvc表单标签库

    HTML密码框 <td><form:label path="password">密码:</form:label></td><t ...

  6. 使用php封装APP接口

    php封装APP接口 我们先来介绍Json的封装方法 json_encode函数传递中文的话,输出后是乱码的,针对这个问题我觉得有必要做一个解释: 其实json_encode对中文那不是乱码,只是js ...

  7. 【JZOJ4761】【NOIP2016提高A组模拟9.7】鼎纹

    题目描述 输入 输出 样例输入 2 3 4 4 2 1100 0110 1100 10 01 10 00 2 2 2 2 11 11 01 10 样例输出 YES NO 数据范围 解法 由于鼎纹中的第 ...

  8. 服务网关zuul----zuul中的动态刷新路由配置

    Spring Cloud实战小贴士:Zuul处理Cookie和重定向 所以解决该问题的思路也很简单,我们只需要通过设置sensitiveHeaders即可,设置方法分为两种: 全局设置: zuul.s ...

  9. linux 系统下如何进行用户之间的切换

    切换用户的命令是su,su是(switch user)切换用户的缩写.通过su命令,可以从普通用户切换到root用户,也可以从root用户切换到普通用户.从普通用户切换到root用户需要密码(该密码是 ...

  10. C# 显示实现接口

    显示实现接口的目的就是为了同名方法. 接口是多实现的,比如说一个方法要实现多个接口,然后这几个接口中有同名方法,这个时候就用到了接口的显示实现. 显示实现接口 成员方法的调用: 接口名.方法名  访问 ...