【LeetCode日记】 874. 模拟行走机器人

这是一道 LeetCode 难度为 easy 的题目,没有高深的算法,有的只是套路,我们来看下。

原题地址:https://leetcode-cn.com/problems/walking-robot-simulation/submissions/

题目描述

【LeetCode日记】 874. 模拟行走机器人

思路

这道题之所以是简单难度,是因为其没有什么技巧。你只需要看懂题目描述,然后把题目描述转化为代码即可。

唯一需要注意的是查找障碍物的时候如果你采用的是线形查找会很慢,很可能会超时。

我实际测试了一下,确实会超时

  • 一种方式是使用排序,然后二分查找,如果采用基于比较的排序算法,那么这种算法的瓶颈在于排序本身,也就是

  • 另一种方式是使用集合,将 obstacles 放入集合,然后需要的时候进行查询,查询的时候的时间复杂度为

这里我们采用第二种方式。

接下来我们来“翻译”一下题目。

  • 由于机器人只能往前走。因此机器人往东西南北哪个方向走取决于它的朝向

  • 我们使用枚举来表示当前机器人的朝向

  • 题目只有两种方式改变朝向,一种是左转(-2),另一种是右转(-1)。

  • 题目要求的是机器人在运动过程中距离原点的最大值,而不是最终位置距离原点的距离。

为了代码书写简单,我建立了一个直角坐标系。用机器人的朝向和 x 轴正方向的夹角度数来作为枚举值,并且这个度数是 0 <= deg < 360。我们不难知道,其实这个取值就是0, 90,180,270 四个值。那么当 0 度的时候,我们只需要不断地 x+1,90 度的时候我们不断地 y + 1 等等。

【LeetCode日记】 874. 模拟行走机器人

关键点解析

  • 理解题意,这道题容易理解错题意,求解为最终位置距离原点的距离

  • 建立坐标系

  • 使用集合简化线形查找的时间复杂度。

代码

代码支持:Python3

Python3 Code:

【LeetCode日记】 874. 模拟行走机器人

1、一行代码就可以通过 LeetCode?来看下我是怎么做到的!

2、原来状态机也可以用来刷LeetCode?

3、神一样的随机算法

4、掌握前缀表达式真的可以为所欲为!

【LeetCode日记】 874. 模拟行走机器人