1337 银行里的迷宫

时间限制: 1 s

空间限制: 128000 KB

题目等级 : 白银 Silver

传送门

题目描述 Description

楚楚每一次都在你的帮助下过了一关又一关(比如他开宴会)。这一次,你的才华让楚楚被劫住了!(好心办了坏事啊,下次不理他了=_=)

歹徒: hehe~

楚楚:(冷汗ing)干啥^_^!(PS:现在还笑得出来!!!)

歹徒:抢劫的说~

楚楚:你们想干啥!!(PS:不是告诉你了,是抢劫~)

歹徒:这里是银行的陷阱,也就是一个迷宫……你要带我们离开这里……否则……

楚楚:(想:那你是咋抓到我的,郁闷)好吧……

楚楚认为生命还是最重要的……(大不了出去以后找警察……)

于是,他认命了……

他从歹徒口中得知这是一个方形的迷宫(歹徒老大:你还要啥形状的,跟我说一声!),他们的位置是[1,1],要走到[n,m],长是n,宽是m,这是一个很大的迷宫,里面有陷阱(小明:能不能踩进去的,说!楚楚:当然不能,不过可以用轻功,多花一秒蓄力~用轻功走过的陷阱会石化,变成路,而且刚好走过~ 歹徒想:虾米轻功~明明是杀人利器~还好没和他打起来~),还有墙(PS:说一声,墙不能穿过,虽有轻功,但是还是过不去墙,这个墙也是银行的秘密~即使你是神犇也不行哦~ 楚楚:又坑我~)。(小明:路呢? 楚楚:废话,当然有,只不过这是银行机密,不能说!)

楚楚想在最短时间里走出迷宫(小明:否则歹徒会发怒的,对不对? 楚楚:废话!),若是超过了歹徒老大的忍耐时间time,那就……

(楚楚:小明……SOS,别忘了帮我报警!! 传呼机:嘀,嘀,嘀…… 楚楚:咋么可以这样!可恶!)于是,他顺便还要去找电话报个警(报警不需要时间,打通即可。且电话机可能有多个,但也没有可能没有~)。

楚楚:我的预感告诉我,这个迷宫只能向右或下走~郁闷了~

输入描述 Input Description

第1行是n,m, time,三个整数。

第2到n+1行每行有m个字母(有大写也有小写的)(楚楚:歹徒真笨~,就不能翻译一下吗~)。

字母解析:T(t)是陷阱,W(w)是墙,R(r)是路,A(a)是电话~ (遇到不认识的字符就~算之为路!)

输出描述 Output Description

仅一行走出迷宫的最小时间t(走一步要一秒的说),不能在规定时间走出迷宫,或者打不了电话,请输出“Oh my god!”(不包括引号)。

样例输入 Sample Input

3 3 100

RRR

WWA

TRR

样例输出 Sample Output

4

数据范围及提示 Data Size & Hint

时间限制 Time Limitation

各个测试点1s

注释 Hint

10%的数据 n≤20,m≤20

100%的数据 n≤500,m≤500,time≤100000,不保证[1,1]或者[n,m]不是墙的说,且若[1,1]或者[n,m]不是路,那么就不能活着回去了……

数据解析:

由于楚楚一开始就站在1,1上,所以走这一块不用时间~

/*
dfs 递归T 50分.
*/
#include<iostream>
#include<cstdio>
#define MAXN 501
using namespace std;
int n,m,g[MAXN][MAXN],maxt,tot,ans=1000001;
int dx[3]={0,1,0},dy[3]={0,0,1},flag;
bool s[MAXN][MAXN];
void dfs(int x,int y)
{
if(n==x&&m==y&&flag)
{
ans=min(ans,tot);
return ;
}
for(int i=1;i<=2;i++)
{
int xx=x+dx[i],yy=y+dy[i],a;
if(g[xx][yy]&&xx<=n&&yy<=m)
{
a=g[xx][yy];
tot+=g[xx][yy],g[xx][yy]=0;
if(s[xx][yy]) flag++;
dfs(xx,yy);
g[xx][yy]=a,tot-=a;
if(s[xx][yy]) flag--;
}
}
}
int main()
{
char x;
cin>>n>>m>>maxt; for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
{
cin>>x;
if(x=='T'||x=='t')
g[i][j]=2;
else if(x=='W'||x=='w')
g[i][j]=0;
else if(x=='A'||x=='a')
g[i][j]=1,s[i][j]=true;
else g[i][j]=1;
}
if((!g[1][1]||!g[1][1])||(!g[n][m]||!g[n][m]))
{
printf("Oh my god!\n");
return 0;
}
dfs(1,1);
if(ans<=maxt)
printf("%d",ans);
else printf("Oh my god!");
return 0;
}
/*
棋盘型DP.
路径步数转移.
AC
神奇的 toupper函数()
C++ cstring库函数int toupper(char c)将小写字母转换为大写.
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#define MAXN 501
using namespace std;
int n,m,t,dp[MAXN][MAXN],g[MAXN][MAXN],s[MAXN][MAXN];
bool flag;
int main()
{
char x;
cin>>n>>m>>t;
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
{
cin>>x;
x=toupper(x);
if(x=='T')
g[i][j]=2;
else if(x=='W')
g[i][j]=0;
else if(x=='A')
g[i][j]=1,s[i][j]=true;
else g[i][j]=1;
} if((!g[1][1]||!g[1][1])||(!g[n][m]||!g[n][m]))
{
printf("Oh my god!\n");
return 0;
}
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
{
if(i==1&&j==1) continue;
dp[i][j]=MAXN*MAXN;
if(!g[i][j]) continue;
if(s[i][j]) flag=true;
if(i>=2)
dp[i][j]=min(dp[i][j],dp[i-1][j]+1);
if(j>=2)
dp[i][j]=min(dp[i][j],dp[i][j-1]+1);
if(g[i][j]==2) dp[i][j]++;
}
if(flag&&dp[n][m]<=t)
printf("%d",dp[n][m]);
else printf("Oh my god!");
return 0;
}

Codevs 1337 银行里的迷宫的更多相关文章

  1. codevs——T1337 银行里的迷宫

     时间限制: 1 s  空间限制: 128000 KB  题目等级 : 白银 Silver 题解       题目描述 Description 楚楚每一次都在你的帮助下过了一关又一关(比如他开宴会). ...

  2. codevs与noi做题改错本目录

    从2016.2.13开始: 1.  排序超时的问题---------目录:-测试习题 2.  超高精度乘法超时问题-----------目录:高精度计算 算法:快速傅里叶算法. 压位算法 3. 高精度 ...

  3. 【线段树/数学/扩展欧几里得】 Bzoj 3913:奇数国

    Description 在一片美丽的大陆上有100000个国家,记为1到100000.这里经济发达,有数不尽的账房,并且每个国家有一个银行.某大公司的领袖在这100000个银行开户时都存了3大洋,他惜 ...

  4. bzoj 2707 [SDOI2012]走迷宫(SCC+高斯消元)

    Description Morenan被困在了一个迷宫里.迷宫可以视为N个点M条边的有向图,其中Morenan处于起点S,迷宫的终点设为T.可惜的是,Morenan非常的脑小,他只会从一个点出发随机沿 ...

  5. BZOJ 2707: [SDOI2012]走迷宫( tarjan + 高斯消元 )

    数据范围太大不能直接高斯消元, tarjan缩点然后按拓扑逆序对每个强连通分量高斯消元就可以了. E(u) = 1 + Σ E(v) / degree(u) 对拍时发现网上2个程序的INF判断和我不一 ...

  6. [BZOJ2707]走迷宫

    Description Morenan被困在了一个迷宫里.迷宫可以视为N个点M条边的有向图,其中Morenan处于起点S,迷宫的终点设为T.可惜的是,Morenan非常的脑小,他只会从一个点出发随机沿 ...

  7. HDU 2102 A计划(BFS/DFS走迷宫)

    A计划 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submis ...

  8. 【BZOJ2707】[SDOI2012]走迷宫 Tarjan+拓扑排序+高斯消元+期望

    [BZOJ2707][SDOI2012]走迷宫 Description Morenan被困在了一个迷宫里.迷宫可以视为N个点M条边的有向图,其中Morenan处于起点S,迷宫的终点设为T.可惜的是,M ...

  9. 6.House Robber(简单版抢银行)

    Level:   Easy 题目描述: You are a professional robber planning to rob houses along a street. Each house ...

随机推荐

  1. 《C语言程序设计现代方法》第1章 C语言概述

    C语言的特点:C语言是一种底层语言.C语言是一种小型语言.C语言是一种包容性语言. C语言的优点:高效.可移植.功能强大.灵活.标准库.与UNIX系统集成. C语言的缺点:C程序更容易隐藏错误.C程序 ...

  2. jQuery技术内幕预览版.pdf1

    第一章 总体构架 jQuery模块可以分为3部分:入口模块.底层支持模块和功能模块 浏览器功能测试模块提供了针对不同浏览器功能和bug的测试结果,其它模块基于测试结果解决浏览器之间的兼容性问题 回调函 ...

  3. [struts2]Struts遍历标签<s:iterator>总结 [转]

    转至:http://blog.csdn.net/lufeng66/article/details/7338098 struts2的s:iterator 可以遍历 数据栈里面的任何数组,集合等等 以下几 ...

  4. 微信小程序正式发布!这是最全的上手指南

    2017 年 1 月 9 日,是一个值得载入互联网史册的日子. 这一天,零点刚过,张小龙和他的团队,在夜色笼罩下,正式发布了微信小程序. 所以,从这一刻开始,只要有开发者登录小程序后台,并在「开发管理 ...

  5. php分页类代码和使用

    在这要说的一点就是如果你做的分页是有搜索条件的,那么就可以用下面的代码,然后调用之后在new Page()里面把连接加进去就可以了.例如: $href="http://www.***.cn/ ...

  6. SpringMVC接收页面表单参数(转)

    作者:CN.programmer.Luxh 和java相关 一个普通的表单. 表单的代码如下: <%@ page language="java" contentType=&q ...

  7. ABAP ALV表头的实现

    ABAP实现ALV表头的DEMO: 效果: 源代码: *&------------------------------------------------------------------- ...

  8. 推荐一个很好的富文本web编辑器UEditor

    前天产品提了一个编辑器的bug,本人找是找到了问题的症结,就是不好改.框架是压缩兼混淆后的代码.查一下,好多年前的框架... 咨询了一个同事有关旧框架的事情,他也建议我升级编辑器并帮忙帮我找了UEdi ...

  9. 80端口被system占用的问题

    80端口被system占用的问题今天启动Apache的时候发现无法启动-80端口被占用. 检查进程发现是system进程id=4给占用了.这个是系统进程 检查服务,看看IIS.没发现问题. 检查了半天 ...

  10. Hadoop的辉煌还能延续多久?

    摘要:Hadoop已经成为大数据的代名词.短短几年间,Hadoop从一种边缘技术成为事实上的标准.而另一方面,MapReduce在谷歌已不再显赫.当企业瞩目MapReduce的时候,谷歌好像早已进入到 ...