【LeetCode日记】 874. 模拟行走机器人
这是一道 LeetCode 难度为 easy 的题目,没有高深的算法,有的只是套路,我们来看下。
原题地址:https://leetcode-cn.com/problems/walking-robot-simulation/submissions/
题目描述
思路
这道题之所以是简单难度,是因为其没有什么技巧。你只需要看懂题目描述,然后把题目描述转化为代码即可。
唯一需要注意的是查找障碍物的时候如果你采用的是线形查找
会很慢,很可能会超时。
我实际测试了一下,确实会超时
一种方式是使用排序,然后二分查找,如果采用基于比较的排序算法,那么这种算法的瓶颈在于排序本身,也就是。
另一种方式是使用集合,将 obstacles 放入集合,然后需要的时候进行查询,查询的时候的时间复杂度为。
这里我们采用第二种方式。
接下来我们来“翻译”一下题目。
由于机器人只能往前走。因此机器人往东西南北哪个方向走取决于它的
朝向
。我们使用枚举来表示当前机器人的
朝向
。题目只有两种方式改变
朝向
,一种是左转(-2),另一种是右转(-1)。题目要求的是机器人在
运动过程中距离原点的最大值
,而不是最终位置距离原点的距离。
为了代码书写简单,我建立了一个直角坐标系。用机器人的朝向和 x 轴正方向的夹角度数
来作为枚举值,并且这个度数是 0 <= deg < 360
。我们不难知道,其实这个取值就是0
, 90
,180
,270
四个值。那么当 0 度的时候,我们只需要不断地 x+1,90 度的时候我们不断地 y + 1 等等。
关键点解析
理解题意,这道题容易理解错题意,求解为
最终位置距离原点的距离
建立坐标系
使用集合简化线形查找的时间复杂度。
代码
代码支持:Python3
Python3 Code:
推荐阅读
1、一行代码就可以通过 LeetCode?来看下我是怎么做到的!
3、神一样的随机算法