题目描述

游戏界面是一个长为 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】 飞扬的小鸟的更多相关文章

  1. Codevs 3729==洛谷P1941 飞扬的小鸟

    P1941 飞扬的小鸟 456通过 2.4K提交 题目提供者该用户不存在 标签动态规划2014NOIp提高组 难度提高+/省选- 提交该题 讨论 题解 记录   题目描述 Flappy Bird 是一 ...

  2. P1941 飞扬的小鸟(背包)

    P1941 飞扬的小鸟 细节题 上升是完全背包 下降是01背包 (数组访问越界本机怎么能过???(大雾)) #include<iostream> #include<cstdio> ...

  3. 洛谷 P1941 飞扬的小鸟

    洛谷 P1941 飞扬的小鸟 原题链接 首先吐槽几句 noip都快到了,我还不刷起联赛大水题! 题目描述 Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节 ...

  4. [洛谷P1941] 飞扬的小鸟

    洛谷题目链接:飞扬的小鸟 题目描述 Flappy Bird是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画面右方的管道缝隙.如果小鸟一不小心撞到了 ...

  5. [NOIP2014] 提高组 洛谷P1941 飞扬的小鸟

    题目描述 Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画面右方的管道缝隙.如果小鸟一不小心撞到了水管或者掉在地上的话,便 ...

  6. luogu P1941 飞扬的小鸟

    题目描述 Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画面右方的管道缝隙.如果小鸟一不小心撞到了水管或者掉在地上的话,便 ...

  7. 洛谷P1941飞扬的小鸟——细节DP

    题目:https://www.luogu.org/problemnew/show/P1941 此题主要注意许多细节,详见代码. 代码如下: #include<iostream> #incl ...

  8. P1941 飞扬的小鸟[dp]

    题目描述 Flappy Bird是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画面右方的管道缝隙.如果小鸟一不小心撞到了水管或者掉在地上的话,便宣 ...

  9. P1941 飞扬的小鸟

    此题很容易写出方程,由以前的知识可以迁移得,本题可以用完全背包的方法进行优化,使用滚动数组即可得到答案. //莫名奇妙60分.不知道什么细节出了错. #include <bits/stdc++. ...

  10. 2018.11.06 洛谷P1941 飞扬的小鸟(背包)

    传送门 上升看成完全背包. 下降看成01背包. 注意边界转移就行了. 代码: #include<bits/stdc++.h> using namespace std; inline int ...

随机推荐

  1. BZOJ4559: [JLoi2016]成绩比较(dp 拉格朗日插值)

    题意 题目链接 Sol 想不到想不到.. 首先在不考虑每个人的真是成绩的情况下,设\(f[i][j]\)表示考虑了前\(i\)个人,有\(j\)个人被碾压的方案数 转移方程:\[f[i][j] = \ ...

  2. 95%的中国网站需要重写CSS

    95%的中国网站需要重写CSS 很长一段时间,我都使用12px作为网站的主要字体大小.10px太小,眼睛很容易疲劳,14px虽容易看清,却破坏页面的美感.唯独12px在审美和视力方面都恰到好处. 谁对 ...

  3. Apktool(3)——Apktool的使用

    一.apktool的作用 安卓应用apk文件不仅仅是包含有resource和编译的java代码的zip文件,如果你尝试用解压工具(如好压)解压后,你将会获得classes.dex和resource.a ...

  4. git 入门教程之初识git

    初识 git git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目. 背景 我们都知道,Linus 在1991年创建了开源的linux系统,随着不断发展壮大,目前已发展成为最大 ...

  5. Ubuntu-18.04安装Docker

    Docker 介绍 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化.容器是完全使用沙箱机制 ...

  6. sublime text 3 优化配置

    目录 1. sublime text 3 模板插件 SublimeTmpl 配置 修改模板内容格式 修改快捷键 2. 设置sublime text的 TAB 为4个空格 3. 添加markdown支持 ...

  7. Linux中对swap分区的配置

    swap分区的安装与正常分区的安装大致相同,我这里就只说一下不同 大家可先看我上一篇的安装:https://www.cnblogs.com/feiquan/p/9219447.html 1.查看swa ...

  8. Multiple Server Query Execution报The result set could not be merged..

    在SQL Server中使用Multiple Server Query Execution这个功能做数据库维护或脚本发布时非常方便,昨天由于磁盘空间原因,删除清理了大量的软件和组件,结果导致SSMS客 ...

  9. MS SQL CASE WHEN 的用法

    前言 由于经常使用 case when 的2种情况方式,如果=1 则*** 否则 *** 结束.久而久之,都以为只能这么用,都忘记了Case WHEN 的用法. 示例   ,              ...

  10. JavaWeb入门笔记

    Java web笔记 一.HTTP协议 HTTP(超文本传输协议),它是一种主流B/S架构中应用的通信协议.具有以下特点: 1.无状态 服务端不会记录客户端每次提交的请求,服务器一旦相应客户端之后,就 ...