题目链接: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. windows 和 linux 安装 tensorflow

    安装 跟往常一样,我们用 Conda 来安装 TensorFlow.你也许已经有了一个 TensorFlow 环境,但要确保你安装了所有必要的包. OS X 或 Linux 运行下列命令来配置开发环境 ...

  2. @hdu - 5503@ EarthCup

    目录 @description@ @solution@ @accepted code@ @details@ @description@ n 个队伍两两之间比赛,保证没有平局. 现在给出 n 个队伍分别 ...

  3. Pytorch源码与运行原理浅析--网络篇(一)

    前言 申请的专栏开通了,刚好最近闲下来了,就打算开这个坑了hhhhh 第一篇就先讲一讲pytorch的运行机制好了... 记得当时刚刚接触的时候一直搞不明白,为什么自己只是定义了几个网络,就可以完整的 ...

  4. ORACLE 创建pfile和spfile

        使用服务器参数文件spfile创建文本参数文件pfile:1,SQL> create pfile from spfile="/u01/app/oracle/product/9. ...

  5. input上传图片并预览

    首先说一下input 大家都知道上传文件,图片是通过input 的file进行上传的. 1. 首先是样式 大家都知道input在HTML的代码为 <input type="file&q ...

  6. Window setTimeout() 方法

    定义和用法 setTimeout() 方法用于在指定的毫秒数后调用函数或计算表达式. 注意:如果你只想重复执行可以使用 setInterval() 方法. 可以使用clearTimeout()方法来阻 ...

  7. ES6学习笔记第一天

    ## 三.const和let **3.1 const** const用来定义常量,所谓的常量就是值一旦给定后就不变,一次定义终身不变的量 const a = 10; a = 20; 上面的a就是一个常 ...

  8. html(三)注册页面与重定向

    注册和登陆的建立是通过界面post提交表单然后在测试界面获取提交的值,进行判断. 1.测试传来的值,是否为空,将值传回到测试界面: ("Reg.jsp?errorCode=" + ...

  9. springBoot中“MockMvc”的进行Controller进行单元测试:application/octet-stream' not supported问题小结

    解决方案:这个问题其实是Content-type的问题,只需要在相关的代码加入相关Content-type中就可以了,代码如下: mockMvc.perform(post("/user&qu ...

  10. H3CFTP操作示例