0874. 模拟行走机器人
题目地址(874. 模拟行走机器人)
https://leetcode-cn.com/problems/walking-robot-simulation/submissions/
题目描述
前置知识
hashtable
公司
暂无
思路
这道题之所以是简单难度,是因为其没有什么技巧。你只需要看懂题目描述,然后把题目描述转化为代码即可。
唯一需要注意的是查找障碍物的时候如果你采用的是线形查找
会很慢,很可能会超时。
我实际测试了一下,确实会超时
一种方式是使用排序,然后二分查找,如果采用基于比较的排序算法,那么这种算法的瓶颈在于排序本身,也就是$O(NlogN)$。
另一种方式是使用集合,将 obstacles 放入集合,然后需要的时候进行查询,查询的时候的时间复杂度为$O(1)$。
这里我们采用第二种方式。
接下来我们来“翻译”一下题目。
由于机器人只能往前走。因此机器人往东西南北哪个方向走取决于它的
朝向
。我们使用枚举来表示当前机器人的
朝向
。题目只有两种方式改变
朝向
,一种是左转(-2),另一种是右转(-1)。题目要求的是机器人在
运动过程中距离原点的最大值
,而不是最终位置距离原点的距离。
为了代码书写简单,我建立了一个直角坐标系。用机器人的朝向和 x 轴正方向的夹角度数
来作为枚举值,并且这个度数是 0 <= deg < 360
。我们不难知道,其实这个取值就是0
, 90
,180
,270
四个值。那么当 0 度的时候,我们只需要不断地 x+1,90 度的时候我们不断地 y + 1 等等。
关键点解析
理解题意,这道题容易理解错题意,求解为
最终位置距离原点的距离
建立坐标系
空间换时间
代码
代码支持: Python3
Python3 Code:
复杂度分析
时间复杂度:$O(N * M)$, 其中 N 为 commands 的长度, M 为 commands 数组的平均值。
空间复杂度:$O(obstacles)$
更多题解可以访问我的 LeetCode 题解仓库:https://github.com/azl397985856/leetcode 。 目前已经 37K star 啦。
关注公众号力扣加加,努力用清晰直白的语言还原解题思路,并且有大量图解,手把手教你识别套路,高效刷题。
最后更新于