Time Limit: 1 second

Memory Limit: 128 MB

【问题描述】

在经过地球防卫小队的数学家连续多日的工作之后,外星人发的密码终于得以破解。它告诉我们在地球某一处的古老遗迹中,存在

有对抗这次灾难的秘密道具。防卫小队立刻派出了一个直升机小分队,迅速感到了这处遗迹。要进入遗迹,需要通过一段迷之

阶梯。登上阶梯必须要按照它要求方法,否则就无法登上阶梯。它要求的方法有以下三个限制:

1. 如果下一步阶梯的高度只比当前阶梯高1,则可以直接登上。

2. 除了第一步阶梯外,都可以从当前阶梯退到前一步阶梯。

3. 当你连续退下k后,你可以一次跳上不超过当前阶梯高度2^k的阶梯。比如说你现在位于第j步阶梯,并且是从第j + k步阶梯退下

来的。那么你可以跳到高度不超过当前阶梯高度 + 2^k的任何一步阶梯。跳跃这一次只算一次移动。

开始时我们在第1步阶梯。由于时间紧迫,我们需要用最少的移动次数登上迷之阶梯。请你计算出最少的移动步数。

[数据范围]

对于50%的数据:1 <= N <= 20

对于100%的数据:1 <= N <= 200

每步阶梯高度不超过2^31-1

【输入格式】

第1行:一个整数N,表示阶梯步数

第2行:N个整数,依次为每层阶梯的高度,保证递增

【输出格式】

第1行:一个整数,如果能登上阶梯,输出最小步数,否则输出-1

Sample Input

5

0 1 2 3 6

Sample Output

7

【题目链接】:http://noi.qz5z.com/viewtask.asp?id=t092

【题解】



代码1

动态规划

设f[i]表示到第i级阶梯所需要的最小步骤数;

f[i] = f[i-1]+1;(h[i]==h[i-1]+1);

f[i] = min(f[i],f[j+k]+k+1);

(这里k = log2(h[i]-h[j]),且j+k<=i-1)

这里第二个方程相当于从第j+k个位置跳到了第j个位置,然后再跳到i位置;

这里考虑的也是最后的结果吧;

就是第i级阶梯是怎么样走过来的;

从结果去想状态的转移;

代码2是记忆化搜索

需要调到2s才能出解



【代码1】动态规划

#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
using namespace std;
#define LL long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define rei(x) scanf("%d",&x) const int dx[9] = {0,1,-1,0,0,-1,-1,1,1};
const int dy[9] = {0,0,0,-1,1,-1,1,-1,1};
const double pi = acos(-1.0);
const int MAXN = 200+10; int n;
int a[MAXN],f[MAXN],top[MAXN][32];
LL two[32]; int main()
{
//freopen("F:\\rush.txt","r",stdin);
two[0] = 1;
rep1(i,1,31)
two[i] = two[i-1]*2;
rei(n);
rep1(i,1,n) rei(a[i]);
memset(f,0x3f3f3f3f,sizeof f);
f[1] = 0;
rep1(now,2,n)
{
if (a[now]==a[now-1]+1)
f[now] = f[now-1]+1;
rep1(i,1,now-1)
{
int d = a[now]-a[i],k;
for (k = 0;k <= 31;k++)
if (two[k]>=d)
break;
if (i+k<=now-1)
f[now] = min(f[now],f[i+k]+k+1);
}
}
if (f[n]<0x3f3f3f3f)
printf("%d\n",f[n]);
else
puts("-1");
return 0;
}

【代码2】记忆化搜索

#include <cstdio>
#include <algorithm>
#include <cstring>
#include <cmath>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define LL long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define rei(x) scanf("%d",&x)
#define rel(x) scanf("%I64d",&x) typedef pair<int,int> pii;
typedef pair<LL,LL> pll; const int dx[9] = {0,1,-1,0,0,-1,-1,1,1};
const int dy[9] = {0,0,0,-1,1,-1,1,-1,1};
const double pi = acos(-1.0);
const int MAXN = 200+10; int n;
int a[MAXN],f[MAXN][32],top[MAXN][32];
LL two[32]; void dfs(int now,int k,int step)
{
if (f[now][k]<step)
return;
f[now][k] = step;
if (now==n) return;
int ma = top[now][k];
rep2(i,ma,now+1)
dfs(i,0,step+1);
if (now>1)
dfs(now-1,k+1,step+1);
} int main()
{
//freopen("F:\\rush.txt","r",stdin);
two[0] = 1;
rep1(i,1,31)
two[i] = two[i-1]*2;
rei(n);
rep1(i,1,n) rei(a[i]);
rep1(i,1,n)
{
if (a[i+1]==a[i]+1)
top[i][0] = i+1;
else
top[i][0] = i;
rep1(j,1,31)
{
LL ma = a[i]+two[j];
int k;
for (k = top[i][j-1];k <= n;k++)
if (ma<a[k])
break;
top[i][j] = k-1;
}
}
memset(f,0x3f3f3f3f,sizeof f);
dfs(1,0,0);
if (f[n][0]<0x3f3f3f3f)
printf("%d\n",f[n][0]);
else
puts("-1");
return 0;
}

【t092】迷之阶梯的更多相关文章

  1. P1929 迷之阶梯

    题目描述 在经过地球防卫小队的数学家连续多日的工作后,外星人发的密码终于得以破解.它 告诉我们在地球某一处的古老遗迹中,存在有对抗这次灾难的秘密武器.防卫小队立即赶 到这处遗迹.要进入遗迹,需要通过一 ...

  2. 洛谷P1929 迷之阶梯

    P1929 迷之阶梯 题目描述 在经过地球防卫小队的数学家连续多日的工作后,外星人发的密码终于得以破解.它 告诉我们在地球某一处的古老遗迹中,存在有对抗这次灾难的秘密武器.防卫小队立即赶 到这处遗迹. ...

  3. 洛谷 P1929 迷之阶梯

    题目传送门 解题思路: f[i]表示跳到第i层的最少移动次数,如果可以从下面一级跳上来,那么直接跳上来,如果跳不上来,那就往后退,退到不能退或能跳上第i层 AC代码: #include<iost ...

  4. CONTEST36 小Z的模拟赛(2)

    A.小Z的可恶路障 题目:http://www.luogu.org/problem/show?pid=U126 题解:暴力也可以过吧.我为了保险先求了一次最短路,然后枚举这条最短路上的所有边... 代 ...

  5. Java中文字符处理的四大迷题

    虽然计算机对英文字符的支持非常不错,我们也恨不得写的程序只会处理英文的数据,但是昨为中国人,无可避免地要处理一些中文字符.当很简单的一件事情,遇到了中文,一切就不同了!本文就会讲述实际生产环境中遇到的 ...

  6. [LeetCode] Word Ladder 词语阶梯

    Given two words (beginWord and endWord), and a dictionary, find the length of shortest transformatio ...

  7. 你知道 Twitter,但你可能不知道它的 “成长模式” 和 “参与阶梯”

    当你为产品创建 “成长模式” 时,你需要回答以下关键问题(类Twitter产品:http://www.jinhusns.com/Products/Download/?type=xcj ): 目标:产品 ...

  8. [No00002E]关于大数据,你不知道的6个迷思

    还是那个观点:计算机,编程语言,互联网,大数据等等都只是工具! 导语:看过美剧<纸牌屋>没?知道这部"白宫甄嬛传"为什么会火吗?靠的是大!数!据! 过去两年,在 Net ...

  9. 迷之this?(转)

    1. 迷之this 对于刚开始进行 JavaScript 编程的开发者来说,this 具有强大的魔力,它像谜团一样需要工程师们花大量的精力去真正理解它. 在后端的一些编程语言中,例如 Java.PHP ...

随机推荐

  1. Java8中的LocalDateTime工具类

    网上搜索了半天都没有找到Java8的LocalDateTime的工具类,只好自己写了一个,常用功能基本都有.还在用Date的Java同道该换换了. 个人项目地址:https://github.com/ ...

  2. day39-Spring 05-Spring的AOP:不带有切点的切面

    Spring底层的代理的实现: 不带切点的切面是对类里面的所有的方法都进行拦截. 做Spring AOP的开发需要两个包:一个是AOP的包,一个是AOP联盟的包(因为规范是由AOP联盟提出来的). 用 ...

  3. oracle-ORA-01567错误

    删除日志4时将在线索1中保留少于两个日志文件

  4. 撸了一个微信小程序项目

    学会一项开发技能最快的步骤就是:准备,开火,瞄准.最慢的就是:准备,瞄准,瞄准,瞄准-- 因为微信小程序比较简单,直接开撸就行,千万别瞄准. 于是乎,趁着今天上午空气质量不错,撸了一个小程序,放在了男 ...

  5. 容器云平台使用体验:数人云Crane(续)

    数人云在9月6日开通了容器管理面板Crane的试用活动,这是国内首个基于DockerSwarmKit的容器管理工具.它具有Docker原生编排功能,采用轻量化架构,帮助开发者快速搭建DevOps环境, ...

  6. jq向元素附加数据

    --------data() 方法向被选元素附加数据,或者从被选元素获取数据.--------- --------removeData() 方法删除之前通过 data() 方法设置的数据.------ ...

  7. 2018-11-3-WPF-内部的5个窗口之-MediaContextNotificationWindow

    title author date CreateTime categories WPF 内部的5个窗口之 MediaContextNotificationWindow lindexi 2018-11- ...

  8. 【UML】之简单概括 标签: uml图形 2014-11-09 11:24 1130人阅读 评论(24) 收藏

    29号开始看UML的视频,由于之前看视频总是一拖拖上半个月,所以这次打算速战速决,而且UML视频的讲解和内容并不算多,也比较容易懂,到后期更是花了很多时间来举例子巩固各种图的画法,所以这次花了11天初 ...

  9. 洛谷 1463[SDOI2005] 反素数ant

    题目描述 对于任何正整数x,其约数的个数记作g(x).例如g(1)=1.g(6)=4. 如果某个正整数x满足:g(x)>g(i) 0<i<x,则称x为反质数.例如,整数1,2,4,6 ...

  10. offsetheight 和clientheight、scrollheight、scrollTop区别

    clientHeight:元素客户区的大小,指的是元素内容及其边框所占据的空间大小(经过实践取出来的大多是视口大小) scrollHeight: 滚动大小,指的是包含滚动内容的元素大小(元素内容的总高 ...