题目名称 |
|
地图探险 |
|
题目类型 |
|
传统型 |
|
目录 |
explore |
可执行文件名 |
输入文件名 |
explore.in |
输出文件名 |
explore.out |
每个测试点时限 |
秒 |
内存限制 |
|
测试点数目 |
|
测试点是否等分 |
是 |
提交源程序文件名
【题目描述】
小 A 打算前往一片丛林去探险。丛林的地理环境十分复杂,为了防止迷路,他先派遣了一个机器人前去探路。
丛林的地图可以用一个 行 列的字符表来表示。我们将第 行第 列的位置的坐标记作 (,)。如果这个位置的字符为 x
,即代表这个位置上有障碍,不可通过。反之,若这个位置的字符为 .
,即代表这个位置是一片空地,可以通过。
这个机器人的状态由位置和朝向两部分组成。其中位置由坐标 (,) 刻画,它表示机器人处在地图上第 行第 列的位置。而朝向用一个 的整数 表示,其中 代表向东, 代表向南, 代表向西, 代表向北。
初始时,机器人的位置为 ,朝向为 。保证初始时机器人所在的位置为空地。接下来机器人将要进行 次操作。每一步,机器人将按照如下的模式操作:
- 假设机器人当前处在的位置为 ,朝向为 。则它的方向上的下一步的位
置 定义如下:若 ,则令 ,若 ,则令 ,若 ,则令 ,若 ,则令 。
- 接下来,机器人判断它下一步的位置是否在地图内,且是否为空地。具体地说,它判断 是否满足 ,,且 位置上是空地。如果条件成立,则机器人会向前走一步。它新的位置变为 ,且朝向不变。如果条件不成立,则它会执行“向右转”操作。也就是说,令 (即 除以 的余数),且它所处的位置保持不变,但朝向由 变为 。
小 A 想要知道,在机器人执行完 步操作之后,地图上所有被机器人经过的位置(包括起始位置)有几个。