h [1,16] hours

all_v=h*12 intervals

n [2,25] lakes

fi inital intervals

fi-di*v v [0,all_v)

题意,做每件事情的最小时间间隔是5分钟,走路是5分钟的整数倍,钓鱼时间必须是5分钟的整数倍。我们不妨把5分钟定义为一个时间单位,不如就临时定义“1慧”为5分钟吧。

有一条道,它旁边有n个湖,依次编号1-n,从湖i到i+1需要花费ti(慧)

john从湖1开始,只能朝编号大的湖走。可以停下选择钓鱼或者继续钓鱼。

一旦在湖i停下钓鱼,可以选择钓k(慧),k时整数。选择湖i的第一慧能钓的鱼是fi,然后每过1慧,钓的鱼少di

问题是怎样钓鱼钓鱼数最多?如果有多种方案,则选择第一个湖钓鱼数最长的;还有多组就第二个湖,第三个湖……

输入第一行是T,代表T组数据

每组数据

第一行是n,代表有n个湖

第二行是h,代表总共john总共有h个小时,也就是h*12(慧)

接下来n行,每行有两个数 fi,di

接下来是(n-1)数,代表ti

输出

输出在每个湖钓鱼的分钟数(注意不是“慧”,我们要换回题目说的了),都好分割

然后输出能钓多少鱼?

预先计算出在湖i钓h慧得鱼数 lake[i][h]

枚举加贪心

枚举在湖i终止所有的钓鱼活动,则走路的时间就已经明确不变了,不妨先剔除。假设剔除后有hui 慧时间

我们可以1慧1慧来钓鱼,选取所有当前所有湖中可获得鱼最多的湖。之后更新这个湖可以钓的鱼的数量。

注意:虽然看起来这样做是在各个湖之中切换来切换去,但是实际上不管我们1慧1慧选择的湖的顺序是怎么样的,我们都可以对应成在第i个湖钓鱼pi慧时间,是并没有违反题目的钓鱼规则。

#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<cmath>
#include<algorithm>
#include<iostream>
using namespace std;
const int max_hui=400;
const int maxn=25;
int n,hui;
int t[maxn+2],f[maxn+2],d[maxn+2],ans_list[maxn+2],st[maxn+2],ans;
int tf[maxn+2],tans_list[maxn+2],tans; void work(int hui,int n)
{
int x;
ans=0;
memset(ans_list,0,sizeof(ans_list));
for (int h=1;h<=hui;++h) {
x=0;
for (int i=1;i<n;++i)
if (f[x]<f[i])
x=i;
ans_list[x]++;
ans+=f[x];
if (f[x]>d[x])
f[x]-=d[x];
else
f[x]=0;
}
} bool is_better(int n)
{
int i;
if (ans>tans) return true;
if (ans<tans) return false;
for (i=0;i<n-1;++i)
if (ans_list[i]!=tans_list[i])
break;
return ans_list[i]>tans_list[i];
} int main()
{
void init();
void backup();
bool first=true;
while (1) {
if (first)
first=false;
else
printf("\n");
init();
if (!n) break;
tans=-1;
memcpy(tf,f,sizeof(f));//backup
for (int end=0;end<n;++end) {
work(hui-st[end],end+1);
if (is_better(end+1)) {
tans=ans;
memcpy(tans_list,ans_list,sizeof(ans_list));
}
memcpy(f,tf,sizeof(f));//restore
}
for (int i=0;i<n-1;++i)
printf("%d, ",tans_list[i]*5);
printf("%d \n",tans_list[n-1]*5);
printf("Number of fish expected: %d \n",tans);
}
return 0;
} void init()
{
scanf("%d",&n);
if (n==0) return;
scanf("%d",&hui);hui*=12;
for (int i=0;i<n;++i)
scanf("%d",f+i);
for (int i=0;i<n;++i)
scanf("%d",d+i);
st[0]=0;
for (int i=0;i<n-1;++i) {
scanf("%d",t+i);
st[i+1]=st[i]+t[i];
}
}

poj1042题解的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

随机推荐

  1. http各个版本(1/1.1/2)对比

    参考的文章: 从理论到实践 全面理解HTTP/2 HTTP协议以及HTTP2.0/1.1/1.0区别 综合阐述http1.0/1.1/2和https 目录: http1.1 长连接 HTTP 1.1支 ...

  2. Task.Run()方法总结

    一.从异步方法的声明说起 无返回值的类型异步方法 (1)public async Task MethodName() 带返回值类型的异步方法 (2)public async Task<TResu ...

  3. toj 3019 Hidden Password (最小表示法)

    Hidden Password 时间限制(普通/Java):1000MS/3000MS 运行内存限制:65536KByte总提交: 53 测试通过: 19 描述 Some time the progr ...

  4. 干货!手把手教你使用数据可视化BI软件创建企业变更流程监控大屏

    灯果数据可视化BI软件是新一代人工智能数据可视化大屏软件,内置丰富的大屏模板,可视化编辑操作,无需任何经验就可以创建属于你自己的大屏.大家可以在他们的官网下载软件.   本文以企业变更流程监控大屏为例 ...

  5. JavaScript之if流程控制演练,if写在区间内怎么解决

    什么是编程?通俗意见上来讲,就是把人的思维与步骤通过代码的形式书写展示出来,JavaScript的流程控制包含条件判断if,switch选择,循环for while:if(表达式 条件)=>真{ ...

  6. k8s强制删除pod

    有时候pod一直在Terminating kubectl delete pod xxx --force --grace-period=

  7. 【STM32H7教程】第47章 STM32H7的FMC总线基础知识和HAL库API

    完整教程下载地址:http://www.armbbs.cn/forum.php?mod=viewthread&tid=86980 第47章       STM32H7的FMC总线基础知识和HA ...

  8. Git操作:查看所有分支的提交修改

    我们在廖雪峰Git教程或者一些书籍学习git分支时,大都会学习到这样一个命令git log --graph或者就是单纯的git log,他可以用来查看当前分支.但是这个弊端就是:它只能查看与当前分支有 ...

  9. #《H.264和MPEG-4视频压缩》# 一. 色彩空间

    多数的数字视频应用需要播放彩色的视频信号,所以需要捕获和重现颜色信息.一幅黑白图像的每一个采样点只需要一个像素表示明暗或亮度,而在彩色图像中至少需要3个像素来表示每个像素的色彩.表示亮度和色彩的不同方 ...

  10. Kong 系列【六】添加插件---ip-restriction之黑白名单

    写在前边 本地postMan请求http://192.168.130.131:8000/test-route,可以正常访问,本地IP:192.168.130.1同样在虚拟机环境192.168.130. ...