题目链接: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. HZOJ 走格子

    作者的正解: 对于100%的数据:行动可以分为两种: 1. 步行,花费一个单位的时间移动到4联通的相邻格子中去. 2. 使用传送门,指定一个方向的墙的前面的一个格子,步行至最近的一个墙的面前,使用传送 ...

  2. linux扫盲之CPU模式

    相信研究linux的大大都知道linux有实模式.保护模式.虚拟模式三种. 不多说,拷贝黏贴!  80386开始,cpu有三种工作方式:实模式,保护模式和虚拟8086模式.只有在刚刚启动的时候是rea ...

  3. L05 Laravel 教程 - 电商实战

    https://laravel-china.org/courses/laravel-shop https://laravel-china.org/topics/13206/laravel-shop-c ...

  4. C. Tokitsukaze and Duel 前缀维护

    枚举每一个连续的K的第一个位置,如果是先手胜利,那么前[1 , i-1 ]和[ i+k , n ]区间要么全是0,要么全是1 如果能够平局,那么肯定是[1,i-1],以及[ i+k , n]中有两种情 ...

  5. @noi.ac - 171@ 立方体

    目录 @description@ @solution@ @accepted code@ @details@ @description@ TonyFang 打算送你一些立方体. 你需要在 [1, n] ...

  6. Element-ui学习笔记1

    1.col,row布局注意事项 el-row el-col gutter就是css,span的时候宽度是按boder-box来计算. 将 type 属性赋值为 'flex',可以启用 flex 布局, ...

  7. Python os.getcwd() 方法

    Python os.getcwd() 方法  Python OS 文件/目录方法 概述 os.getcwd() 方法用于返回当前工作目录. 语法 getcwd()方法语法格式如下: os.getcwd ...

  8. SSM整合 mybatis多条件查询与分页

    多条件查询与分页: 通过页面的houseName.floorage获取值传到前端视图(HouseSearchVO)实体类中的houseName,floorage建立houseSearchVO对象. 通 ...

  9. html(二)登陆页面

    今天开始正常上课学习HTML+CSS+JSP  嗯 前两个没讲直接上手! 老师也是很认同我们的呢~ 这是第一个案例 做一个登陆页面,并利用post提交表单 传值到另一个界面接收值. 1.设置值: &l ...

  10. [C++] 获取IE代理服务器的账号密码

    很多程序需要使用'浏览器设置'的代理服务器,IE设置的代理服务器有可能是需要账号密码的.怎样编程获取浏览器设置的代理服务器的账号密码呢? InternetQueryOption(NULL, INTER ...