银行里的迷宫

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上,所以走这一块不用时间~

one。90分代码

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define N 501
using namespace std;
int n,m,t;
char ch;
int main()
{
    scanf("%d%d%d",&n,&m,&t);
    for(int i=1;i<=n;i++)
     for(int j=1;j<=m;j++)
         cin>>ch;
    printf("Oh my god!");
    return 0;
}

two。dfs超时代码

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define N 501
#define maxn 999999
using namespace std;
int xx[2]={0,1},yy[2]={1,0};//只能向右和向下走
int n,m,t,a[N][N],tot,flag,ans=maxn;
bool s[N][N];
char ch;
void dfs(int x,int y)
{
    if(x==n&&y==m&&flag)
    {
        ans=min(ans,tot);
        return ;
    }
    for(int i=0;i<2;i++)
    {
        int ax=x+xx[i],ay=y+yy[i];
        if(ax<=n&&ay<=m&&a[ax][ay])
        {
            int q=a[ax][ay];
            tot+=a[ax][ay],a[ax][ay]=0;
            if(s[ax][ay]) flag++;
            dfs(ax,ay);
            tot-=q,a[ax][ay]=q;
            if(s[ax][ay]) flag--;
        }
    }
}
int main()
{
    scanf("%d%d%d",&n,&m,&t);
    for(int i=1;i<=n;i++)
     for(int j=1;j<=m;j++)
     {
         cin>>ch;
         if(ch==‘T‘||ch==‘t‘) a[i][j]=2;//陷阱
         else  if(ch==‘W‘||ch==‘w‘) a[i][j]=0;//墙,不能走
         else  if(ch==‘A‘||ch==‘a‘) a[i][j]=1,s[i][j]=true;//电话
         else  a[i][j]=1;//路
     }
    if(!a[n][m]||!a[1][1]){ printf("Oh my god!\n");  return 0;  }
    dfs(1,1);
    if(ans<=t) printf("%d",ans);
    else printf("Oh my god!\n") ;
    return  0;
}

three。棋盘DP

科普小贴士

神奇的 toupper函数()
原型:int toupper(int c);
相关函数 isalpha,tolower
头文件:ctype.h
功能:将小写字母转换成大写字母
说明:若参数c为小写字母则将该对映的大写字母返回。

返回值  返回转换后的大写字母,若不须转换则将参数c值返回。

#include<ctype.h>
#include <stdio.h>
int main()
{
    char s[]="aBcDeFgH12345;!#$";
    int i = 0;
    printf("转换前: %s\n",s);
    for(i=0;i<sizeof(s);i++)
    {
        s[i]=toupper(s[i]);
    }
    printf("转换后: %s\n",s);
    return 0;
}  

代码:

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define N 510
#define maxn 999999999
using namespace std;
int n,m,t,a[N][N],tot,dp[N][N];
bool s[N][N],flag;
char ch;
int main()
{
    scanf("%d%d%d",&n,&m,&t);
    for(int i=1;i<=n;i++)
     for(int j=1;j<=m;j++)
     {
         cin>>ch;
         //dp[i][j]=maxn*maxn;
         ch=toupper(ch);//小写转大写
         if(ch==‘T‘) a[i][j]=2;//陷阱
         else  if(ch==‘W‘) a[i][j]=0;//墙,不能走
         else  if(ch==‘A‘) a[i][j]=1,s[i][j]=true;//电话
         else  a[i][j]=1;//路
     }
    if(!a[n][m]||!a[1][1]){ 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;//一定要在上面,否则若下面一句不满足,这句就会不执行
          if(!a[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(a[i][j]==2) dp[i][j]++;//陷阱花两倍的时间
       }
    if(flag&&dp[n][m]<=t) printf("%d\n",dp[n][m]);
    else printf("Oh my god!\n");
    return 0;
}
时间: 2024-10-05 16:00:02

银行里的迷宫的相关文章

codevs——T1337 银行里的迷宫

时间限制: 1 s 空间限制: 128000 KB 题目等级 : 白银 Silver 题解 题目描述 Description 楚楚每一次都在你的帮助下过了一关又一关(比如他开宴会).这一次,你的才华让楚楚被劫住了!(好心办了坏事啊,下次不理他了=_=) 歹徒: hehe~ 楚楚:(冷汗ing)干啥^_^!(PS:现在还笑得出来!!!) 歹徒:抢劫的说~ 楚楚:你们想干啥!!(PS:不是告诉你了,是抢劫~) 歹徒:这里是银行的陷阱,也就是一个迷宫……你要带我们离开这里……否则…… 楚楚:(想:那你

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

Description Morenan被困在了一个迷宫里.迷宫可以视为N个点M条边的有向图,其中Morenan处于起点S,迷宫的终点设为T.可惜的是,Morenan非常的脑小,他只会从一个点出发随机沿着一条从该点出发的有向边,到达另一个点.这样,Morenan走的步数可能很长,也可能是无限,更可能到不了终点.若到不了终点,则步数视为无穷大.但你必须想方设法求出Morenan所走步数的期望值. Input 第1行4个整数,N,M,S,T 第[2, M+1]行每行两个整数o1, o2,表示有一条从o

数据结构应用实例#栈#迷宫寻路

使用数据结构 栈(Stack)来实现一种低级的迷宫寻路的功能.低级是因为无法判断路径是不是最短的. 这里使用的栈结构如图 (这图我选择死亡...) 注意结构体里DataType的实际含义,是另外一个结构体,用于储存二维位置x,y 地图使用一个10x10的二维数组来表示,数字1表示该点是墙壁,0表示可以行走,2表示已经走过的地方. 我们用栈来储存走过的位置,比如我们从起点(4,0)出发,就把(4,0)压入栈,并把该点数值改为2,意为已经来过了.如果遇到死路,那就不停地出栈,直到栈顶的这个点周围有路

[BZOJ2702]走迷宫

Description Morenan被困在了一个迷宫里.迷宫可以视为N个点M条边的有向图,其中Morenan处于起点S,迷宫的终点设为T.可惜的是,Morenan非常的脑小,他只会从一个点出发随机沿着一条从该点出发的有向边,到达另一个点.这样,Morenan走的步数可能很长,也可能是无限,更可能到不了终点.若到不了终点,则步数视为无穷大.但你必须想方设法求出Morenan所走步数的期望值. Input 第1行4个整数,N,M,S,T 第[2, M+1]行每行两个整数o1, o2,表示有一条从o

转:一个计算机专业毕业的银行员工工作感受

先介绍一下我国现在整个银行业及和它相关的行业(证券,保险,IT业)的一些大概情况. 最近几年是我国银行业改革的关键几年,因为2005年我国金融业将全面开放,外资银行将和中国的银行展开全面的竞争.外资银行在管理水平.金融创新能力方面要优于我们.所以,我国的银行只能利用这点时间,积极改革,加快自身的发展,尽快形成自己的核心竞争力. 我国的银行体系如下: 中国人民银行(央行)------执行国家货币政策,发行并控制货币,为其他商业银行提供贷款,作为最后贷款人来稳定金融市场 银监会------对整个银行

centos mysql 实战 第三节课 MySQL里的对象 mysql体系结构 mysql日志 数据类型

centos mysql  实战  第三节课   MySQL里的对象  mysql体系结构  mysql日志   数据类型 上两节课1. MySQL的安装2. MySQL启动方式 MySQL里的对象 今天第一个: MySQL里的对象 查看当前有那些数据库:show databases; drop database test;truncate table mysql.db; mysql里view当成Table对待了,没有单独的命令能备份视图,只能备份表 information_schema 字典库

联通推流量银行 噱头大于实用

眼瞅着当下运营商在于互联网的企业竞争中处于下风,眼瞅着中国移动4G用户蹭蹭蹭地往上涨,中国联通终于按耐不住,开始争抢爆点.不管爆点的评价如何,反正能抢到报刊媒体的头条就行. 好一张大饼!联通流量银行花样百出 11月25日,2014移动互联网流量创新峰会在北京召开,作为主办方的中国联通正式推出流量创新经营产品"流量银行".按照联通官方的说法,"流量银行"是一个针对3G.4G用户的流量管理与交易平台.同时也是一个为企业用户提供精准.高效营销服务的推广平台.甚至"

有关dfs、bfs解决迷宫问题的个人见解

可以使用BFS或者DFS方法解决的迷宫问题! 题目如下: kotori在一个n*m迷宫里,迷宫的最外层被岩浆淹没,无法涉足,迷宫内有k个出口.kotori只能上下左右四个方向移动.她想知道有多少出口是她能到达的,最近的出口离她有多远? 输入描述: 第一行为两个整数n和m,代表迷宫的行和列数 (1≤n,m≤30) 后面紧跟着n行长度为m的字符串来描述迷宫.'k'代表kotori开始的位置,'.'代表道路,'*'代表墙壁,'e'代表出口.保证输入合法. 输出描述: 若有出口可以抵达,则输出2个整数,

SDOI2012 走迷宫

走迷宫 Morenan被困在了一个迷宫里.迷宫可以视为N个点M条边的有向图,其中Morenan处于起点S,迷宫的终点设为T.可惜的是,Morenan非常的脑小,他只会从一个点出发随机沿着一条从该点出发的有向边,到达另一个点.这样,Morenan走的步数可能很长,也可能是无限,更可能到不了终点.若到不了终点,则步数视为无穷大.但你必须想方设法求出Morenan所走步数的期望值. N<=10000,M<=1000000,保证强连通分量的大小不超过100 Clove_unique的题解 首先考虑图是