在一条水平路边,有n个钓鱼湖,从右到左编号为1、2、3……、n。佳佳有H个小时的空余时间,他希望用这些时间尽可能多的钓鱼。他从湖1出发,向右走,有选择的在一些湖边停留一定时间钓鱼,最后在某一湖边结束钓鱼。佳佳测出从第i个湖到第i+1个湖需要走Ti分钟的路,还测出在第i个湖边停留,第一个5分钟可以钓到鱼Fi,以后再每钓5分钟鱼,鱼量减少Di。若时间不足5分钟则无法完成钓鱼。为了简化问题,佳佳假定没有其他人钓鱼,也不会有其他影响因素影响他钓到期望数量的鱼。请编程求出能钓最多鱼的方案。
标签:
3 1
40 10
70 70 70
5 5 5
3 1
20 20
100 50 70
50 20 30
510
270
解析:同POJ 1042 Gone Fishing (贪心)(刘汝佳黑书)
但稍有不同的是,数据范围大了点,原来用priority_queue的代码TLE,由于很多次的插入操作,导致priority_queue的效率体现的不明显,所以直接替换掉,用最朴素的方法反而更快点。
AC代码:
#include <algorithm> #include <queue> #include <iostream> #include <cstdio> #include <cstdlib> using namespace std; const int maxn = 1002; int t[maxn], f[maxn], d[maxn]; struct node{ int f; int d; }; node fish[maxn], p[maxn]; int main(){ #ifdef sxk freopen("in.txt", "r", stdin); #endif // sxk int n, h; while(scanf("%d%d", &n, &h)!=EOF){ h = h * 60; for(int i=1; i<=n-1; i++) scanf("%d", &t[i]); for(int i=1; i<=n; i++) scanf("%d", &fish[i].f); for(int i=1; i<=n; i++) scanf("%d", &fish[i].d); int maxans = 0; for(int i=1; i<=n; i++){ int tc = 0; for(int j=1; j<i; j++) tc += t[j]; for(int j=1; j<=i; j++) p[j] = fish[j]; //直接用数组代替priority_queue int ans = 0; int th = (h - tc) / 5; for(int j=1; j<=th; j++){ int foo = 1; for(int k=1; k<=i; k++) //遍历找最大值 if(p[k].f > p[foo].f) foo = k; ans += p[foo].f; p[foo].f -= p[foo].d; if(p[foo].f < 0) p[foo].f = 0; } if(maxans < ans) maxans = ans; } printf("%d\n", maxans); } return 0; }
标签:
原文地址:http://blog.csdn.net/u013446688/article/details/46454239