题目链接:https://www.luogu.com.cn/problem/P1189

题目大意:

给你一个 \(n \times m\) 的矩阵,其中有一些格子可以走,一些各自不能走,然后有一个点是起点。

你走了 \(q\) 次,每次走的方向(上下左右四个方向)是知道的,但是不知道的是你每次走了多少格(至少 \(1\) 格),问最终你可能处在的位置。

(注意我这里开的变量名和原题描述的变量名不一样,不过不影响理解)

解题思路:

这道题目是其实是一道模拟题。

洛谷上面给的算法标签是“迭代加深”,但是其实这里只涉及“迭代”而没有“加深”。

迭代加深——以我的理解——应该是:

  • 先定一个小目标,搜索的深度不超过 \(1\) 层,看看能不能搜到答案;
  • 如果不行,再把搜索的最大深度设为 \(2\) ,看看能不能找到;
  • 如果不行,再把搜索的最大深度设为 \(3\) ,看看能不能找到;
  • ……
  • 直到设定目标为某一个深度 \(D\) ,并且此时我能够找到答案则退出。

但是其实我们这里没有接触到搜索,而只是将问题分解成了 \(q\) 步。

所以我可以开一个二维数组 \(a[i][j]\) 表示 \((i,j)\) 这个格子可以作为第 \(a[i][j]\) 步的起点。

很显然,一开始我可以这么设:

  • 起点对应的 \(a[i][j]\) 为 \(1\),
  • 不能走的点对应的 \(a[i][j]\) 为 \(-1\),
  • 剩下的点(非起点的能走的点)对应的 \(a[i][j]\) 为 \(0\)

然后我们模拟每一步,我们从 \(1\) 到 \(q\) 来枚举第 \(id\) 步,

假设当前在第 \(id\) 步,

我们再枚举每一个点 \((i,j)\) ,如果 \(a[i][j]\) 恰好等于 \(id\) ,说明可以以 \((i,j)\) 为起点向对应的方向走。

比如第 \(id\) 步的指令是“NORTH”,那么是往北走,

则我们可以循环将 \(a[i-1][j],a[i-2][j], ...\) 置为 \(id+1\),知道渠道不能走的点或者超出地图边界。

最后,我们可以通过判断 \(a[i][j]\) 来还原出这个地图:

  • 如果 \(a[i][j]==id+1\),则该点对应‘*’;
  • 如果 \(a[i][j]==-1\),则该点对应‘X’;
  • 其他情况下,该点对应‘.’。

实现代码如下:

#include <bits/stdc++.h>
using namespace std;
const int maxn = 55;
int n, m, q, a[maxn][maxn]; // n,m表示行和列,q表示方向的数量
char maze[maxn][maxn], ch[11];
bool in_map(int x, int y) { // 判断(x,y)是否在地图中
return x>=0 && x<n && y>=0 && y<m;
}
void go_north(int x, int y, int id) { // 往北走并标记
while (in_map(x, y) && maze[x][y] != 'X') {
a[x][y] = id+1;
x --;
}
}
void go_south(int x, int y, int id) { // 往南走并标记
while (in_map(x, y) && maze[x][y] != 'X') {
a[x][y] = id+1;
x ++;
}
}
void go_west(int x, int y, int id) { // 往西走并标记
while (in_map(x, y) && maze[x][y] != 'X') {
a[x][y] = id+1;
y --;
}
}
void go_east(int x, int y, int id) { // 往东走并标记
while (in_map(x, y) && maze[x][y] != 'X') {
a[x][y] = id+1;
y ++;
}
}
void handle(int id, char ch[]) { // 第id步判断是什么指令然后往相应的方向走
for (int i = 0; i < n; i ++) {
for (int j = 0; j < m; j ++) {
if (a[i][j] == id) {
if (ch[0] == 'N') go_north(i-1, j, id);
else if (ch[0] == 'S') go_south(i+1, j, id);
else if (ch[0] == 'W') go_west(i, j-1, id);
else go_east(i, j+1, id);
}
}
}
}
int main() {
cin >> n >> m;
for (int i = 0; i < n; i ++) cin >> maze[i];
for (int i = 0; i < n; i ++) {
for (int j = 0; j < m; j ++) {
if (maze[i][j] == 'X') a[i][j] = -1;
else if (maze[i][j] == '*') a[i][j] = 1;
}
}
cin >> q;
for (int id = 1; id <= q; id ++) {
cin >> ch;
handle(id, ch);
}
for (int i = 0; i < n; i ++) {
for (int j = 0; j < m; j ++) {
if (maze[i][j] == 'X') putchar('X');
else if (a[i][j] == q+1) putchar('*');
else putchar('.');
}
putchar('\n');
}
return 0;
}

洛谷P1189 SEARCH 题解 迭代加深的更多相关文章

  1. 洛谷P1189'SEARCH'

    题目描述 年轻的拉尔夫开玩笑地从一个小镇上偷走了一辆车,但他没想到的是那辆车属于警察局,并且车上装有用于发射车子移动路线的装置. 那个装置太旧了,以至于只能发射关于那辆车的移动路线的方向信息. 编写程 ...

  2. 洛谷—— P1189 SEARCH

    https://www.luogu.org/problem/show?pid=1189 题目描述 年轻的拉尔夫开玩笑地从一个小镇上偷走了一辆车,但他没想到的是那辆车属于警察局,并且车上装有用于发射车子 ...

  3. 洛谷P1189 逃跑的拉尔夫(SEARCH)

    洛谷1189 SEARCH 题目描述 年轻的拉尔夫开玩笑地从一个小镇上偷走了一辆车,但他没想到的是那辆车属于警察局,并且车上装有用于发射车子移动路线的装置. 那个装置太旧了,以至于只能发射关于那辆车的 ...

  4. 洛谷NOIp热身赛题解

    洛谷NOIp热身赛题解 A 最大差值 简单树状数组,维护区间和.区间平方和,方差按照给的公式算就行了 #include<bits/stdc++.h> #define il inline # ...

  5. 洛谷P2827 蚯蚓 题解

    洛谷P2827 蚯蚓 题解 题目描述 本题中,我们将用符号 ⌊c⌋ 表示对 c 向下取整. 蛐蛐国最近蚯蚓成灾了!隔壁跳蚤国的跳蚤也拿蚯蚓们没办法,蛐蛐国王只好去请神刀手来帮他们消灭蚯蚓. 蛐蛐国里现 ...

  6. 洛谷P1816 忠诚 题解

    洛谷P1816 忠诚 题解 题目描述 老管家是一个聪明能干的人.他为财主工作了整整10年,财主为了让自已账目更加清楚.要求管家每天记k次账,由于管家聪明能干,因而管家总是让财主十分满意.但是由于一些人 ...

  7. [POI 2008&洛谷P3467]PLA-Postering 题解(单调栈)

    [POI 2008&洛谷P3467]PLA-Postering Description Byteburg市东边的建筑都是以旧结构形式建造的:建筑互相紧挨着,之间没有空间.它们共同形成了一条长长 ...

  8. [NOI 2020 Online] 入门组T1 文具采购(洛谷 P6188)题解

    原题传送门 题目部分:(来自于考试题面,经整理) [题目描述] 小明的班上共有 n 元班费,同学们准备使用班费集体购买 3 种物品: 1.圆规,每个 7 元. 2.笔,每支 4 元. 3.笔记本,每本 ...

  9. [洛谷P3948]数据结构 题解(差分)

    [洛谷P3948]数据结构 Description 最开始的数组每个元素都是0 给出n,opt ,min,max,mod 在int范围内 A: L ,R ,X 表示把[l,R] 这个区间加上X(数组的 ...

随机推荐

  1. @codeforces - 117C@ Cycle

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 给定一个竞赛图(有向完全图),请找出里面的某个三元环,或者判断不 ...

  2. Careers/Staffing Index

    Careers/Staffing Index     Not having data governance can hurt your business. Download this eBook to ...

  3. hdu 5723 Abandoned country(2016多校第一场) (最小生成树+期望)

    Abandoned country Time Limit: 8000/4000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others ...

  4. jsp中文乱码六种情况---解决方案

    转 jsp中文乱码六种情况---解决方案 2016年10月22日 21:32:55 阅读数:10672 来源:http://blog.csdn.net/lovesummerforever/articl ...

  5. ccf-201403-3有趣的命令行

    傻逼题,要是考试只能得0分.. 提供几组傻逼数据,这要是在真实的生活中一定是错的... 还是要好好读题吧,全凭自己的感觉就得0分 albw:x 4 ls -a docu Case 1: -a ls - ...

  6. 给radio添加点击事件

    1.单独给每个radio添加点击事件 <fieldset id="form-gra-time"> <legend>请选择日期粒度:</legend&g ...

  7. Java Annotation详解(二): 反射和Annotation

    前面一篇文<Java Annotation详解(一): 理解和使用Annotation>中,我们或许会觉得,Annotation注释其实并没有多大的作用,除了几个内建的Annotation ...

  8. C#的选择语句练习(一)

    1.请输入一个数x,若x<1,则y=x:若1<=x<10,则y=2x-1:若x>=10,则y=3x-11,要求随意输入一个x值,求出y值. 2.输入问题[你有房子吗?],若回答 ...

  9. 高并发下载tomcat下的文件时,发生java.net.SocketException: Connection reset解决方案

    (1)问题产生:使用500个线程并发下载tomcat工程中的一个文件时,服务器出现java.net.SocketException: Connection reset异常, 客户端出现connect ...

  10. RocketMQ(消息重发、重复消费、事务、消息模式)

    分布式开放消息系统(RocketMQ)的原理与实践 RocketMQ基础:https://github.com/apache/rocketmq/tree/rocketmq-all-4.5.1/docs ...