钓鱼

题目

Description



我们把钓鱼的过程放在坐标系里来考虑。图中蓝色的点为船,初始时它的坐标记为(Ax,y)。河深为y,河宽为x。某个时刻会从左边界或右边界游出来一条鱼(左边的往右边游,右边的往左边游),即鱼游出来时的横坐标为0或x,这条鱼每秒会游D个单位长度,鱼的长度为L。初始时刻为0,对于每个时刻x,船可以选择花费1s向左或向右移动最多Q个单位长度,或者选择在当前位置进行钓鱼,钓鱼的动作是瞬间的,且发生在时刻x,鱼还来不及移动就被钓上了。如果选择钓鱼,那么在时刻x就不能动。{x+1时刻可以选择移动}设当前位置为z,将鱼看成一条线段,当线段与直线x=z相交时就认为鱼上钩了,所以一次钓鱼动作可能会钓多条鱼。

聪明的你告诉钓鱼者,在T时刻前最多能钓多少鱼?

Input

输入:

第一行:T

第二行:Maxx,Maxy,表示河宽和河深

第三行:两个数Ax,Q

第四行:N,表示有N条鱼

接下来N行描述每条鱼:每行共五个数,x,y,D,L,time

x表示鱼头的初始位置,保证为0或maxx,y表示鱼头的初始深度,time表示鱼出现的时刻(所有的数都为整数)

Output

输出:

只有一行:ans,表示最多的钓鱼数

Sample Input

3

4 5

4 1

3

0 1 3 1 0

4 2 2 1 0

0 3 3 1 2

Sample Output

3

Data Constraint

100%的数据满足

1<=T,time<=10

1<=Ax,Ay,Q,x,y,D,L<=10

1<=N<=14

30%的数据满足

1<=N<=5

总结

考试的时候想到了状压DP,但没有进一步去想

其实这题的转移方程十分简单,也容易想到,但是就是放弃了

所以说有想法就可以继续钻研下去

题解

首先题目要求的是T时刻前,其实是包括T的

所以说总共会进行T+1次操作

看到N很小,考虑状压

设\(f[i][j][s]\)表示现在是\(i\)时刻,\(j\)位置,鱼的情况是\(s\)(被钓了是1,没有是0)的最大鱼数

转移分两种(以下方程都需要和原来的取\(max\))

  1. 移动。那么\(f[i+1][j-q…j+q][s]=f[i][j][s]\)
  2. 钓鱼。\(f[i+1][j][s1]=f[i][j][s]+sum\)

    \(s1\)表示钓鱼后的情况,\(sum\)表示钓上来的数量

对于判断是否钓上来,可以预处理每条鱼在每一分钟的位置,然后循环扫一遍

初始化\(f[0][Ax][0]=0\),其余的是-1

Code

#include<bits/stdc++.h>
using namespace std;
int t,mx,my,pos,q,n,sum,s1,ans,st[15],de[15],v[15],l[15],_time[15],fh[15],head[15][15],tail[15][15],f[15][15][33000];
int read()
{
int res=0;char ch=getchar();
while (ch<'0'||ch>'9') ch=getchar();
while (ch>='0'&&ch<='9') res=(res<<1)+(res<<3)+(ch-'0'),ch=getchar();
return res;
}
int main()
{
t=read();mx=read();my=read();pos=read();q=read();n=read();
for (int i=1;i<=n;++i)
{
st[i]=read();de[i]=read();v[i]=read();l[i]=read();_time[i]=read();
if (st[i]==0) fh[i]=1;
else fh[i]=-1;
}
for (int i=1;i<=n;++i)
for (int j=0;j<=t;++j)
{
if (_time[i]==j)
{
head[i][j]=st[i];
tail[i][j]=st[i]-fh[i]*l[i];
}
if (_time[i]<j)
{
head[i][j]=head[i][j-1]+fh[i]*v[i];
tail[i][j]=tail[i][j-1]+fh[i]*v[i];
}
}
memset(f,-1,sizeof(f));
f[0][pos][0]=0;
for (int i=0;i<=t;++i)
for (int j=0;j<=mx;++j)
for (int s=0;s<(1<<n);++s)
{
if (f[i][j][s]==-1) continue;
for (int k=max(0,j-q);k<=min(j+q,mx);++k)
f[i+1][k][s]=max(f[i+1][k][s],f[i][j][s]);
sum=0;
s1=s;
for (int k=1;k<=n;++k)
if (_time[k]<=i&&!(s1&(1<<(k-1))))
if ((head[k][i]>=j&&tail[k][i]<=j)||(head[k][i]<=j&&tail[k][i]>=j)) ++sum,s1|=(1<<(k-1));
f[i+1][j][s1]=max(f[i+1][j][s1],f[i][j][s]+sum);
}
ans=-1;
for (int k=0;k<=t+1;++k)
for (int i=0;i<=mx;++i)
for (int j=0;j<(1<<n);++j)
ans=max(ans,f[k][i][j]);
printf("%d\n",ans);
return 0;
}

【NOIP2011模拟11.1】钓鱼的更多相关文章

  1. JZOJ 3509. 【NOIP2013模拟11.5B组】倒霉的小C

    3509. [NOIP2013模拟11.5B组]倒霉的小C(beats) (File IO): input:beats.in output:beats.out Time Limits: 1000 ms ...

  2. JZOJ 3508. 【NOIP2013模拟11.5B组】好元素

    3508. [NOIP2013模拟11.5B组]好元素(good) (File IO): input:good.in output:good.out Time Limits: 2000 ms  Mem ...

  3. 8.1 NOIP模拟11

    8.1 NOIP模拟 11 今天上午返校之后,颓了一会,然后下午就开始考试,中午睡着了,然后刚开始考试的时候就困的一匹,我一看T1,woc,这不是之前线段树专题的题啊,和那道题差不多,所以我..... ...

  4. JZOJ 3518. 【NOIP2013模拟11.6A组】进化序列(evolve)

    3518. [NOIP2013模拟11.6A组]进化序列(evolve) (File IO): input:evolve.in output:evolve.out Time Limits: 1000 ...

  5. JZOJ 3505. 【NOIP2013模拟11.4A组】积木(brick)

    3505. [NOIP2013模拟11.4A组]积木(brick) (File IO): input:brick.in output:brick.out Time Limits: 1000 ms Me ...

  6. JZOJ 3526. 【NOIP2013模拟11.7A组】不等式(solve)

    3526. [NOIP2013模拟11.7A组]不等式(solve) (File IO): input:solve.in output:solve.out Time Limits: 1000 ms M ...

  7. JZOJ 4298. 【NOIP2015模拟11.2晚】我的天

    4298. [NOIP2015模拟11.2晚]我的天 (File IO): input:ohmygod.in output:ohmygod.out Time Limits: 1000 ms Memor ...

  8. JZOJ 3929. 【NOIP2014模拟11.6】创世纪

    3929. [NOIP2014模拟11.6]创世纪 (Standard IO) Time Limits: 1000 ms Memory Limits: 65536 KB Description 上帝手 ...

  9. JZOJ 3928. 【NOIP2014模拟11.6】射击

    3928. [NOIP2014模拟11.6]射击 (Standard IO) Time Limits: 1000 ms Memory Limits: 65536 KB Description 有问题, ...

随机推荐

  1. 重载符operator() -- effective c++ 3rd P71的的隐式类型转换及相关的研究

    class的"operator 返回类型 ()" 的重载 就是对(class)的重载,这个重载符不用参数,参数就是自身,并且与函数传递的参数括号等价 如 func(c), 并且多个 ...

  2. Odoo环境搭建之问题readme

    环境及工具 Windows,PyCharm Community Edition,postgresql-13.0-1 启动odoo环境 python odoo-bin 如果你只是还是空壳,启动odoo之 ...

  3. 如何理解直播APP源码开发中的音视频同步

    视频 直播APP源码的视频的播放过程可以简单理解为一帧一帧的画面按照时间顺序呈现出来的过程,就像在一个本子的每一页画上画,然后快速翻动的感觉. 但是在实际应用中,并不是每一帧都是完整的画面,因为如果直 ...

  4. 【Mycat】作为Mycat核心开发者,怎能不来一波Mycat系列文章?

    写在前面 Mycat是基于阿里开源的Cobar产品而研发,Cobar的稳定性.可靠性.优秀的架构和性能以及众多成熟的使用案例使得Mycat一开始就拥有一个很好的起点,站在巨人的肩膀上,我们能看到更远. ...

  5. ubuntu18.04下stlink的一种安装方法

    安装前准备: 从软件包存储库中安装以下软件包: git gcc或clang或mingw32-gcc或mingw64-gcc(C编译器:很可能已经存在gcc) build-essential (在基于D ...

  6. Gromacs分子动力学模拟流程概述

    Gromacs分子动力学模拟主要可以分为以下几个步骤,不同的体系步骤可能略有不同. 在开始之前,先简单了解一下预平衡: 分子动力学模拟的最终目的是对体系进行抽样,然后计算体系的能量,各种化学键,成分分 ...

  7. full nat

    在餐馆吃饭时,连接无线网络后访问某网页会自动弹出一个认证页面,我想大家都经历过..... 其网络拓扑如下: sta-------------网络设备--------------公网 比如sta 终端i ...

  8. 三:redis启动后的基础知识

    Redis启动后的杂项基础知识 1.单进进程 单进程模型来处理客户端的请求.对读写等事件的响应是通过对epoll函数的包装来做到的.Redis的实际处理速度完全依靠主进程的执行效率       Epo ...

  9. 为什么删除的Ceph对象还能get

    前言 在很久以前在研究一套文件系统的时候,当时发现一个比较奇怪的现象,没有文件存在,磁盘容量还在增加,在研究了一段时间后,发现这里面有一种比较奇特的处理逻辑 这套文件系统在处理一个文件的时候放入的是一 ...

  10. 无所不能的Embedding4 - Doc2vec第二弹[skip-thought & tf-Seq2Seq源码解析]

    前一章Doc2Vec里提到,其实Doc2Vec只是通过加入Doc_id捕捉了文本的主题信息,并没有真正考虑语序以及上下文语义,n-gram只能在局部解决这一问题,那么还有别的解决方案么?依旧是通用文本 ...