Description

一天, 一个画家在森林里写生,突然爆发了山洪,他需要尽快返回住所中,那里是安
全的。
森林的地图由R行C列组成,空白区域用点“.”表示,洪水的区域用“*”表示,而
岩石用“X”表示,另画家的住所用“D”表示,画家用“S”表示。
有以下几点需要说明:
1、 每一分钟画家能向四个方向移动一格(上、下、左、右)
2、 每一分钟洪水能蔓延到四个方向的相邻格子(空白区域)
3、 洪水和画家都不能通过岩石区域
4、 画家不能通过洪水区域(同时也不行,即画家不能移到某个格子,该格子在画家达到的同时被洪水蔓延到了,这也是不允许的)
5、 洪水蔓不到画家的住所。
给你森林的地图,编写程序输出最少需要花费多长时间才能从开始的位置赶回家中。
 

Input

输入第一行包含两个整数R和C(R,C<=50)。
接下来R行每行包含C个字符(“.”、“*”、“X”、“D”或“S”)。地图保证只有一个“D”和一个“S”。

Output

输出画家最快安全到达住所所需的时间,如果画家不可能安全回家则输出“KAKTUS”。
 

Sample Input

输入1:
3 3
D.*
...
.S. 输入2:
3 3
D.*
...
..S 输入3:
3 6
D...*.
.X.X..
....S.

Sample Output

输出1:
3 输出2:
KAKTUS 输出3:
6

  这道题主要考的是bfs和预处理,我们模拟一下就能过,因为它的数据太蒻。

  首先,我们读入整个地图,不断地扫描整个地图,然后每一次发现岩浆就将它合法扩散。

  然后我们处理人,这就要跑一遍bfs了,找到就输出,不然就输出KAKTUS。

下面上代码:

#include<iostream>
#include<cstdio>
using namespace std;
int tim,n,m,last;
bool p;
char mp[][][];
void before(){
for(int i=;i<=;i++){
for(int j=;j<=n;j++){
for(int k=;k<=m;k++){
if(mp[j][k][i-]=='*'){
if(mp[j+][k][i]!='D'&&mp[j+][k][i]!='X') mp[j+][k][i]='*';
if(mp[j][k+][i]!='D'&&mp[j][k+][i]!='X') mp[j][k+][i]='*';
if(mp[j-][k][i]!='D'&&mp[j-][k][i]!='X') mp[j-][k][i]='*';
if(mp[j][k-][i]!='D'&&mp[j][k-][i]!='X') mp[j][k-][i]='*';
}
}
}
}
}
int main(){
ios::sync_with_stdio(false);
cin>>n>>m;
for(int i=;i<=n;i++){
for(int j=;j<=m;j++){
cin>>mp[i][j][];
for(int k=;k<=;k++){
mp[i][j][k]=mp[i][j][k-];
}
}
}
before();
while(tim<=){
tim++;
for(int i=;i<=n;i++){
for(int j=;j<=m;j++){
if(mp[i][j][tim-]=='S'){
if(mp[i+][j][tim]=='D'){
cout<<tim;
return ;
}
if(mp[i][j+][tim]=='D'){
cout<<tim;
return ;
}
if(mp[i-][j][tim]=='D'){
cout<<tim;
return ;
}
if(mp[i][j-][tim]=='D'){
cout<<tim;
return ;
}
if(mp[i+][j][tim]=='.') mp[i+][j][tim]='S';
if(mp[i][j+][tim]=='.') mp[i][j+][tim]='S';
if(mp[i-][j][tim]=='.') mp[i-][j][tim]='S';
if(mp[i][j-][tim]=='.') mp[i][j-][tim]='S';
}
}
}
}
cout<<"KAKTUS";
}

谢谢阅读

题解1235. 洪水 (Standard IO)的更多相关文章

  1. JZOJ 5326. LCA 的统计 (Standard IO)

    5326. LCA 的统计 (Standard IO) Time Limits: 1000 ms Memory Limits: 131072 KB Description Input Output S ...

  2. JZOJ 5307. 【NOIP2017提高A组模拟8.18】偷窃 (Standard IO)

    5307. [NOIP2017提高A组模拟8.18]偷窃 (Standard IO) Time Limits: 1000 ms Memory Limits: 262144 KB Description ...

  3. JZOJ 5286. 【NOIP2017提高A组模拟8.16】花花的森林 (Standard IO)

    5286. [NOIP2017提高A组模拟8.16]花花的森林 (Standard IO) Time Limits: 1000 ms Memory Limits: 131072 KB Descript ...

  4. JZOJ 5305. 【NOIP2017提高A组模拟8.18】C (Standard IO)

    5305. [NOIP2017提高A组模拟8.18]C (Standard IO) Time Limits: 1000 ms Memory Limits: 131072 KB Description ...

  5. JZOJ 5257. 小X的佛光 (Standard IO)

    5257. 小X的佛光 (Standard IO) Time Limits: 2000 ms Memory Limits: 524288 KB Description Input Output Sam ...

  6. JZOJ 5258. 友好数对 (Standard IO)

    5258. 友好数对 (Standard IO) Time Limits: 1000 ms Memory Limits: 524288 KB Detailed Limits Description I ...

  7. JZOJ 1349. 最大公约数 (Standard IO)

    1349. 最大公约数 (Standard IO) Time Limits: 1000 ms Memory Limits: 65536 KB Description 小菜的妹妹小诗就要读小学了!正所谓 ...

  8. JZOJ 1736. 扑克游戏 (Standard IO)

    1736. 扑克游戏 (Standard IO) Time Limits: 1000 ms Memory Limits: 128000 KB Description 有一棵无穷大的满二叉树,根为sta ...

  9. JZOJ 1776. 经济编码 (Standard IO)

    1776. 经济编码 (Standard IO) Time Limits: 1000 ms Memory Limits: 128000 KB Description 为降低资料储存的空间或增加资料传送 ...

随机推荐

  1. python 模块调用的几种方式

    在python里面又很多模块,或者引用第三方模块,python 模块调用的几种方式,下面详细解说 1,import 模块名 2,from 模块 import  模块里面的小功能 3,from  模块 ...

  2. 关于html5 video

    获取视频长度 <video id="video" width="200px" height="auto" src="vide ...

  3. Spring事务嵌套引发的问题--Transaction rolled back because it has been marked as rollback-only

    转载https://blog.csdn.net/f641385712/article/details/80445912 读了两边才找到问题

  4. Leetcode Lect7 哈希表

    传统的哈希表 对于长度为n的哈希表,它的存储过程如下: 根据 key 计算出它的哈希值 h=hash(key) 假设箱子的个数为 n,那么这个键值对应该放在第 (h % n) 个箱子中 如果该箱子中已 ...

  5. 重绘ComboBox —— 让ComboBox多列显示

    最近在维护一个winform项目,公司购买的是DevExpress控件 (请问怎么联系DevExpress工作人员? 我想询问下,广告费是怎么给的.:p),经过公司大牛们对DevExpress控件疯狂 ...

  6. [书接上一回]在Oracle Enterprise Linux (v5.7) 中安装DB - (3/4)

    安装p10404530_112030_Linux-x86-64_6of7.zip解压下的example. 修改软件路径,为dbhome_1. 安装好数据,则可以进行快照操作! 删除安装文件. 输入db ...

  7. python基础--内置函数map

    num_1=[1,2,10,5,3,7] # num_2=[] # for i in num_1: # num_2.append(i**2) # print(num_2) # def map_test ...

  8. [python 学习] requests 库的使用

    1.get请求 # -*- coding: utf-8 -*- import requests URL_IP = "http://b.com/index.php" pyload = ...

  9. shiro框架在springboot项目中的应用

    地址:https://blog.csdn.net/taojin12/article/details/88343990 地址2:https://blog.csdn.net/bicheng4769/art ...

  10. linux运维、架构之路-网络基础

    一. 常用网络设备 1.交换机:实现多台主机之间互相通讯的需求 交换机实现互相通讯的要求: ①主机身份标识信息:mac地址,利用源mac和目标mac地址,进行身份信息识别 ②主机通过交换机识别目标主机 ...