题目大意

  游戏界面是一个长为n ,高为 m 的二维平面,其中有k 个管道(忽略管道的宽度)。小鸟始终在游戏界面内移动。小鸟从游戏界面最左边任意整数高度位置出发,到达游戏界面最右边时,游戏完成。小鸟每个单位时间沿横坐标方向右移的距离为1 ,竖直移动的距离由玩家控制。如果点击屏幕,小鸟就会上升一定高度X ,每个单位时间可以点击多次,效果叠加;如果不点击屏幕,小鸟就会下降一定高度Y 。小鸟位于横坐标方向不同位置时,上升的高度X 和下降的高度Y 可能互不相同。小鸟高度等于0 或者小鸟碰到管道时,游戏失败。小鸟高度为 m 时,无法再上升。现在,请你判断是否可以完成游戏。如果可以 ,输出最少点击屏幕数;否则,输出小鸟最多可以通过多少个管道缝隙。

题解

  本题最简单的动规便是定义$f(i,j)$为第$i$个时间,高度为$j$时最少的上升步数,转移为UpdMin$f(i+1,j-Y_i),f(i,j)+1$,UpdMin$f(i+1,j+kX_i),f(i,j)+k$。然而这样时间复杂度为$O(nm^2)$,不能AC。我们想想怎么消掉那个$k$呢?我们可以这样想:对于每一个$j$,在当前时刻$t$时,我们先点屏幕一次,小鸟移到下一个时间$t'$,随后你就可以随便点屏幕让鸟在时刻$t'$中不断地上升,来更新其它高度的动规值了。这可以看作在$t'$时,把高度作为背包容量,物品体积为$X_t$,价值为$1$,动规值为$f(t',j)$的、每种物品至少选一个的完全背包了。

  注意:

  1. 先由X更新,再由Y更新,因为由X更新时,必须要满足连续地点屏幕的条件,而如果Y在前,可能会导致先不点屏幕让小鸟下降,然后再点屏幕让小鸟在$t'$时上升,不合题意。
  2. 我们只要在刷表时只由合法状态往后更新即可,以后的j如果在管道内,我们也不用管。一方面节省代码量,另一方面完全背包更新时也会需要飞到管道里中的答案。
  3. 对于点屏幕卡在屏幕上端的情况,由越界的情况往下刷即可。
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std; #define UpdateMin(x, y) x = min(x, y)
const int MAX_LEN = 10010, MAX_H = 1010 * 2, MAX_COL = MAX_LEN, INF = 0x3f3f3f3f;
int TotLen, TotH, TotCol;
int RiseLen[MAX_LEN], DecLen[MAX_LEN];
int High[MAX_LEN], Low[MAX_LEN];
bool ReachT;
int Ans; void DP()
{
static int F[2][MAX_COL];
memset(F[0], 0, sizeof(F[0]));
int passCnt = 0;
for (int i = 0; i < TotLen; i++)
{
bool noAns = true;
int top = min(TotH, High[i] - 1), top2 = min(TotH, High[i + 1] - 1);
for (int h = Low[i] + 1; h <= min(TotH, High[i] - 1); h++)
{
if (F[i & 1][h] < INF)
{
noAns = false;
break;
}
}
if (noAns)
{
Ans = passCnt;
return;
}
if (High[i] < INF)
passCnt++;
memset(F[i + 1 & 1], INF, sizeof(F[i + 1 & 1]));
for (int h = Low[i] + 1; h <= top; h++)
UpdateMin(F[i + 1 & 1][h + RiseLen[i]], F[i & 1][h] + 1);
for (int h = 1; h <= top2; h++)
UpdateMin(F[i + 1 & 1][h + RiseLen[i]], F[i + 1 & 1][h] + 1);
for (int h = max(Low[i] + 1, DecLen[i] + 1); h <= top; h++)
UpdateMin(F[i + 1 & 1][h - DecLen[i]], F[i & 1][h]);
if (High[i + 1] == INF)
for (int dh = 1; dh <= RiseLen[i]; dh++)
UpdateMin(F[i + 1 & 1][TotH], F[i + 1 & 1][TotH + dh]);
}
Ans = INF;
for (int h = 1; h <= TotH; h++)
UpdateMin(Ans, F[TotLen & 1][h]);
if (Ans == INF)
Ans = passCnt;
else
ReachT = true;
} int main()
{
scanf("%d%d%d", &TotLen, &TotH, &TotCol);
for (int i = 0; i < TotLen; i++)
scanf("%d%d", RiseLen + i, DecLen + i);
memset(High, INF, sizeof(High));
for (int i = 0; i < TotCol; i++)
{
int p, low, high;
scanf("%d%d%d", &p, &low, &high);
High[p] = high;
Low[p] = low;
}
DP();
printf("%d\n%d\n", ReachT, Ans);
return 0;
}

  

luogu1941 飞扬的小鸟的更多相关文章

  1. P1907飞扬的小鸟

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

  2. [codevs3729]飞扬的小鸟

    [codevs3729]飞扬的小鸟 试题描述 输入 输出 输出文件名为 bird.out. 共两行. 第一行,包含一个整数,如果可以成功完成游戏,则输出 1,否则输出 0. 第二行,包含一个整数,如果 ...

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

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

  4. NOIP2014 飞扬的小鸟

    3. 飞扬的小鸟 (bird.cpp/c/pas) [问题描述] Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画面右方的 ...

  5. Codevs 3729 飞扬的小鸟

    飞扬的小鸟 标签 动态规划 NOIp提高组 2014 难度 提高+/省选- 题目描述 Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小 ...

  6. [NOIP2014][DP]飞扬的小鸟

    [NOIP2014]飞扬的小鸟 ——!x^n+y^n=z^n 题目描述: Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画 ...

  7. Luogu 1941 【NOIP2014】飞扬的小鸟 (动态规划)

    Luogu 1941 [NOIP2014]飞扬的小鸟 (动态规划) Description Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度 ...

  8. UOJ #17. 【NOIP2014】飞扬的小鸟 背包DP

    #17. [NOIP2014]飞扬的小鸟 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4902  Solved: 1879 题目连接 http:// ...

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

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

随机推荐

  1. IDEA修改背景图片和主题代码风格

    使用IDEA有一段时间了,之前为了写代码没时间折腾这玩意,以前使用Eclipse的时候一次性折腾好了,现在把之前Eclipse的配置再配到IDEA里面来,下面是效果图.Eclipse的设置见:点击这里 ...

  2. [Python3网络爬虫开发实战] 3.1.4-分析Robots协议

    利用urllib的robotparser模块,我们可以实现网站Robots协议的分析.本节中,我们来简单了解一下该模块的用法. 1. Robots协议 Robots协议也称作爬虫协议.机器人协议,它的 ...

  3. [Python3网络爬虫开发实战] 1.6.1-Flask的安装

    Flask是一个轻量级的Web服务程序,它简单.易用.灵活,这里主要用来做一些API服务. 1. 相关链接 GitHub:https://github.com/pallets/flask 官方文档:h ...

  4. python爬虫入门02:教你通过 Fiddler 进行手机抓包

    哟~哟~哟~ hi起来 everybody 今天要说说怎么在我们的手机抓包 通过 python爬虫入门01:教你在Chrome浏览器轻松抓包 我们知道了 HTTP 的请求方式 以及在 Chrome 中 ...

  5. Discuz论坛广告横幅大图在百度app内无法显示,百度app默认开启了广告屏蔽

    问题由来 前段时间搭的一个Discuz论坛上挂了2个广告横幅,网站的话收录还不错,然后客户就反应百度app上无法看到横幅. 由于我没有下载百度app,看不到效果我将信将疑,因为电脑,手机浏览器都是ok ...

  6. ..net 3.5新特性之用this关键字为类添加扩展方法

    具体用法如下: public static class ClassHelper { //用this 声明将要吧这个方法附加到Student对象 public static bool CheckName ...

  7. HDU 3157 Crazy Circuits

    Crazy Circuits Time Limit: 2000ms Memory Limit: 32768KB This problem will be judged on HDU. Original ...

  8. 数据库 SQL SQL转义

    SQL转义 @author ixenos 前言 类似文件分隔符在不同系统的实现不同,我们需要一个中间的转义字符来作为接口,各厂商再具体实现 而SQL的转义语法主要为了支持各种数据库普遍支持的特性,但各 ...

  9. 2017-10-01-morning

    T1 位运算1(bit) Time Limit:1000ms   Memory Limit:128MB 题目描述 LYK拥有一个十进制的数N.它赋予了N一个新的意义:将N每一位都拆开来后再加起来就是N ...

  10. Memcached的几种Java客户端(待实践)

    其实现在来尝试Memcached的客户端估计会有点过气,因为现在大势基本都在Redis那边. Memcached Client目前有3种: Memcached Client for Java(已经停止 ...