题目链接: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. css white-space属性

    css white-space属性 规定段落中的文本不进行换行

  2. Java排序算法总结

    1.冒泡排序 冒泡排序是排序算法中最基本的一种排序方法,该方法逐次比较两个相邻数据的大小并交换位置来完成对数据排序,每次比较的结果都找出了这次比较中数据的最大项,因为是逐次比较,所以效率是O(N^2) ...

  3. poj 3743 LL’s cake (PSLG,Accepted)

    3743 -- LL’s cake 搞了好久都过不了,看了下题解是用PSLG来做的.POJ 2164 && LA 3218 Find the Border (Geometry, PSL ...

  4. apply、call、bind方法调用

    ---恢复内容开始--- 首先这三个方法的作用都是用来改变this的值,而this的值一般有几种情况. 1.函数作为一个对象的一个方法来调用,此时this的值指向对象. var a={ v:0; f: ...

  5. 洛谷P3366 【模板】最小生成树 题解

    题目链接:https://www.luogu.org/problem/P3366 最小生成树模板题. Kruskal算法 算法思想:给边按边权从小到大排序,然后遍历每一条边,如果边上的两个点不在同一个 ...

  6. tp5 字段验证表中是否唯一

    namespace app\ps\validate; /** * 客户分类验证器 */ class CustomerCategory extends PsBase { // 验证规则 protecte ...

  7. P1099 双连击

    题目描述 我们假设一个二位整数 \(N(10 \le N \le 99)\) ,它的十位上的数字是 \(A\) ,个位上的数字是 \(B\) ,如果 \(A\) 和 \(B\) 的比例关系满足 \(A ...

  8. [学习笔记]k短路

    A*:我已经忘了怎么写了,反正n=30,m=1000都能卡掉... 正解:可持久化左偏树+堆维护可能集合 原论文:http://www.docin.com/p-1387370338.html 概括: ...

  9. 高并发WEB服务的演变

    一.越来越多的并发连接数 现在的Web系统面对的并发连接数在近几年呈现指数增长,高并发成为了一种常态,给Web系统带来不小的挑战.以最简单粗暴的方式解决,就是增加 Web系统的机器和升级硬件配置.虽然 ...

  10. 给培训学校讲解ORM框架的课件

    导读:这是我给某培训学校培训.net程序员所设计的课件,他们普遍反映太难了,是这样吗?