【P1941】 飞扬的小鸟
题目描述
游戏界面是一个长为 nn,高为 mm 的二维平面,其中有 kk 个管道(忽略管道的宽度)。
小鸟始终在游戏界面内移动。小鸟从游戏界面最左边任意整数高度位置出发,到达游戏界面最右边时,游戏完成。
小鸟每个单位时间沿横坐标方向右移的距离为 11,竖直移动的距离由玩家控制。如果点击屏幕,小鸟就会上升一定高度 XX,每个单位时间可以点击多次,效果叠加;如果不点击屏幕,小鸟就会下降一定高度 YY。小鸟位于横坐标方向不同位置时,上升的高度 XX 和下降的高度 YY 可能互不相同。
小鸟高度等于 00 或者小鸟碰到管道时,游戏失败。小鸟高度为 mm 时,无法再上升。
现在,请你判断是否可以完成游戏。如果可以,输出最少点击屏幕数;否则,输出小鸟最多可以通过多少个管道缝隙。
输入输出格式
输入格式:
第 11 行有 33 个整数 n, m, kn,m,k,分别表示游戏界面的长度,高度和水管的数量,每两个整数之间用一个空格隔开;
接下来的 nn 行,每行 22 个用一个空格隔开的整数 XX 和 YY,依次表示在横坐标位置 0 \sim n-10∼n−1 上玩家点击屏幕后,小鸟在下一位置上升的高度 XX,以及在这个位置上玩家不点击屏幕时,小鸟在下一位置下降的高度 YY。
接下来 kk 行,每行 33 个整数 P, L, HP,L,H,每两个整数之间用一个空格隔开。每行表示一个管道,其中 PP 表示管道的横坐标,LL 表示此管道缝隙的下边沿高度,HH 表示管道缝隙上边沿的高度(输入数据保证 PP 各不相同,但不保证按照大小顺序给出)。
输出格式:
共两行。
第一行,包含一个整数,如果可以成功完成游戏,则输出 11,否则输出 00。
第二行,包含一个整数,如果第一行为 11,则输出成功完成游戏需要最少点击屏幕数,否则,输出小鸟最多可以通过多少个管道缝隙。
题目解析
完全背包DP,用x[i],y[i]表示在i处点击上升和下降的距离 DP[i][j]表示到达i,j处的最少点击次数
则可得出DP转移方程
DP[i][j]=min(DP[i][j],DP[i-][j+y[i]]+); //下降
DP[i][j]=min(DP[i-][j-x[i]]+,DP[i][j-x[i]]+); //上升
if(j>=high[i]+||j<low[i])DP[i][j]=inf;//处理水管
DP[i][j]=min(DP[i][m],DP[i][j]);//高出边界的情况
上述转移方程中的第二个,之所以可以从DP[i][j]转移而来,是因为在一个时间点可以点击多次,所以可以在同一个维度内更新
第四个方程,是处理溢出最大高度m的情况,因为在原题目中说明当到达顶部不可以再向上移动,而转移式中会溢出顶部[0,M)
当然这一部分也可以用来更新
第三个转移方程一定要在一、二、四转移后使用,因为规则是不能接触管道
做完DP后就可以直接遍历最后一列,若有被更新过得直接输出即可
若没有则代表无法到达终点,这时从后向前遍历,遇到第一个被更新的管道,记录位置,向前数有几个管道就是能通过的最大管道数即可
code:
#include<cstdio>
#include<cstring>
#include<iostream>
#define maxn 10200
#define maxm 2200
using namespace std;
int low[maxn],high[maxn],x[maxn],y[maxn],flag[maxn];
int f[maxn][maxm],n,m,k,P,L,H;
int main()
{
//freopen("1.in","r",stdin);
cin>>n>>m>>k;
for(register int i=;i<=n;i++) cin>>x[i]>>y[i];
for(register int i=;i<=n;i++)
{
high[i]=m; low[i]=;
}
for(register int i=;i<=k;i++)
{
cin>>P>>L>>H;
flag[P]=;
low[P]=L+;;
high[P]=H-;
}
memset(f,0x3f3f3f,sizeof(f));
for(int i=;i<=m;i++) f[][i]=;
for(int i=;i<=n;i++)
{
for(int j=x[i]+;j<=x[i]+m;j++)
f[i][j]=min(f[i-][j-x[i]]+,f[i][j-x[i]]+);
for(int j=m+;j<=x[i]+m;j++)
f[i][m]=min(f[i][m],f[i][j]);
for(int j=;j<=m-y[i];j++)
f[i][j]=min(f[i][j],f[i-][j+y[i]]);
for(int j=;j<low[i];j++)
f[i][j]=0x3f3f3f;
for(int j=high[i]+;j<=m;j++)
f[i][j]=0x3f3f3f;
}
int ans=0x3f3f3f;
for(int i=;i<=m;i++) ans=min(ans,f[n][i]);
if(ans<0x3f3f3f)
{
cout<<<<endl;
cout<<ans<<endl;
return ;
}
int i,j;// 这里定义i,j用来存储坐标,所以下面的循环中不要再定义了
for( i=n;i>=;i--)
{
for( j=;j<=m;j++)
{
if(f[i][j]<0x3f3f3f) break;
}
if(j<=m) break;//若j在m+1的位置代表这一列没有被更新到,否则代表最远到达这里
}
ans=;
for(j=;j<=i;j++)
if(flag[j]) ans++;
cout<<<<endl;
cout<<ans<<endl;
return ;
}
【P1941】 飞扬的小鸟的更多相关文章
- Codevs 3729==洛谷P1941 飞扬的小鸟
P1941 飞扬的小鸟 456通过 2.4K提交 题目提供者该用户不存在 标签动态规划2014NOIp提高组 难度提高+/省选- 提交该题 讨论 题解 记录 题目描述 Flappy Bird 是一 ...
- P1941 飞扬的小鸟(背包)
P1941 飞扬的小鸟 细节题 上升是完全背包 下降是01背包 (数组访问越界本机怎么能过???(大雾)) #include<iostream> #include<cstdio> ...
- 洛谷 P1941 飞扬的小鸟
洛谷 P1941 飞扬的小鸟 原题链接 首先吐槽几句 noip都快到了,我还不刷起联赛大水题! 题目描述 Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节 ...
- [洛谷P1941] 飞扬的小鸟
洛谷题目链接:飞扬的小鸟 题目描述 Flappy Bird是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画面右方的管道缝隙.如果小鸟一不小心撞到了 ...
- [NOIP2014] 提高组 洛谷P1941 飞扬的小鸟
题目描述 Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画面右方的管道缝隙.如果小鸟一不小心撞到了水管或者掉在地上的话,便 ...
- luogu P1941 飞扬的小鸟
题目描述 Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画面右方的管道缝隙.如果小鸟一不小心撞到了水管或者掉在地上的话,便 ...
- 洛谷P1941飞扬的小鸟——细节DP
题目:https://www.luogu.org/problemnew/show/P1941 此题主要注意许多细节,详见代码. 代码如下: #include<iostream> #incl ...
- P1941 飞扬的小鸟[dp]
题目描述 Flappy Bird是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画面右方的管道缝隙.如果小鸟一不小心撞到了水管或者掉在地上的话,便宣 ...
- P1941 飞扬的小鸟
此题很容易写出方程,由以前的知识可以迁移得,本题可以用完全背包的方法进行优化,使用滚动数组即可得到答案. //莫名奇妙60分.不知道什么细节出了错. #include <bits/stdc++. ...
- 2018.11.06 洛谷P1941 飞扬的小鸟(背包)
传送门 上升看成完全背包. 下降看成01背包. 注意边界转移就行了. 代码: #include<bits/stdc++.h> using namespace std; inline int ...
随机推荐
- windows查看笔记本电池使用报告
CMD 下 powercfg /batteryreport /output “C:\battery_report.html” powercfg 参数 /LIST./L 列出所有电源方 ...
- onmouseover和onmouseenter区别
onmouseover和onmouseenter都是鼠标进入时触发,onmouseover在所选元素的子元素间切换的时候也触发! <!doctype html><html lang= ...
- JS 调试中常见的报错的解决办法
报错:Uncaught SyntaxError: Unexpected token o in JSON at position 1 at JSON.parse (<anonymous>) ...
- matlab练习程序(加权最小二乘)
起本篇题目还是比较纠结的,原因是我本意打算寻找这样一个算法:在测量数据有比较大离群点时如何估计原始模型. 上一篇曲面拟合是假设测量数据基本符合均匀分布,没有特别大的离群点的情况下,我们使用最小二乘得到 ...
- SQL Agent Job 报“Access to the remote server is denied because the current security context is not trusted”
SQL Server 2005(Microsoft SQL Server 2005 - 9.00.5000.00)下的一个作业执行一个存储过程,存储过程中动态SQL语句使用链接服务器(Linked S ...
- sql-server的添加数据库文件(日志数据)以及收缩数据库文件(日志数据)
环境: SSMS sql-server2016 一.为数据库添加数据文件 添加日志数据文件 以下是添加数据文件和日志文件的代码 ALTER DATABASE [joinbest] ADD FILE ( ...
- Spring扫面路径配置不全导致异常 org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): 的原因
运行Junit测试类 package cn.bgodata.x.zero.service; import org.junit.Test; import org.junit.runner.RunWith ...
- SQL Server将一列的多行内容拼接成一行
昨天遇到一个SQL Server的问题:需要写一个储存过程来处理几个表中的数据,最后问题出在我想将一个表的一个列的多行内容拼接成一行 比如表中有两列数据 : ep_classes ep_name A ...
- SSH File Transfer遇到错误"too many authentication failures for root".A protocol error was detected......
在SSH Secure Shell 连接Linux centos的时候,遇到F-Secure SSH File Transfer错误"too many authentication fai ...
- [福大软工] Z班 第12次成绩排行榜
注:本次成绩排行榜是针对结对项目二的点评分数 作业要求 http://www.cnblogs.com/easteast/p/7604534.html 评分细则 (1)有贴生成得最"好&quo ...