这是悦乐书的第335次更新,第360篇原创

01 看题和准备

今天介绍的是LeetCode算法题中Easy级别的第205题(顺位题号是874)。网格上的机器人从点(0,0)开始并朝北。机器人可以接收三种可能类型的命令之一:

  • -2:向左转90度。

  • -1:向右转90度。

  • 1 <= x <= 9:向前移动x个单位。

一些网格方块是障碍物。第i个障碍位于网格点(obstacles[i][0],obstacles[i][1])。如果机器人遇到障碍点,机器人将停留在障碍点前一个网格方格上(但仍然会继续执行剩下的指令。)返回机器人从原点开始的最大欧氏距离的平方。例如:

输入:commands = [4,-1,3],obstacles = []
输出:25
说明:机器人位于(3,4),3x3 + 4x4 = 25。

输入:commands = [4,-1,4,-2,4],obstacles = [[2,4]]
输出:65
说明:从(0,0)开始先向北走到(4,0),然后向右,此时朝东,往前走4步,但是在(2,4)遇到了障碍点,所以只能走到(1,4),而不是(4,4),在点(1,4)向左转,此时朝北,向前走4部,到达点(1,8),在(1,8)的平方和最大。

注意

  • 0 <= commands.length <= 10000

  • 0 <= barriers.length <= 10000

  • -30000 <=障碍物[i] [0] <= 30000

  • -30000 <=障碍物[i] [1] <= 30000

  • 答案保证小于2 ^ 31。

02 解题

题目中有几个地方需要先解释下:

  • 机器人的朝向。初始时,机器人是朝北的,根据题目给的例子1,可以推算出,机器人的朝向和上北下南的方向一致。以(0,0)为原点看,向北就是指向y轴的正方向,向东就是指向x轴的正方向,另外两个方向同理。

  • 欧氏距离的平方。其实就是x坐标值和y坐标值的平方和,即X x X + Y x Y之和。

  • 机器人前进的方向。既然机器人有朝向的概念,那么其前进的方向也就包含了四个方向,上下左右,那么机器人前进的方向就具有了周期性,以4为周期。

在了解上面这些信息后,再来看这道题,会清晰很多。根据题目的介绍,commands数组中会遇到3种指令,-2时左转,-1时右转,剩下就是前进多少步了,但是前进的时候需要判断此方向上有没有障碍物,所以我们需要先将表示障碍物的二维数组处理一下,使用HashSet来存储,这样每次只需要判断HashSet中是否包含障碍点即可,而不必去遍历判断。

在机器人可能前进的四个方向上,我们定义一个二维数组,来表示四个方向,此处我们按照上右下左顺时针的方向来定义,你也可以从其他方向开始,只要后面计算周期的时候能够匹配就行。

在执行前进n步的指令时,我们是以1为单位前进,每执行一步就判断一次障碍点。在执行完前进指令后,需要进行比较最大值,最后输出结果值即可。

public int robotSim(int[] commands, int[][] obstacles) {int x = 0, y = 0, max = 0, index = 0;// 将障碍点初始化进HashSet中,以字符串的形式Set<String> set = new HashSet<String>();for (int[] arr : obstacles) {set.add(arr[0]+"-"+arr[1]);}// 四个方向,上右下左,index的取值范围是[0,3]int[][] directions = {{0,1},{1,0},{0,-1},{-1,0}};for (int n : commands) {if (n == -1) {index++;// 右转四次后会回到原点if (index == 4) {index = 0;}} else if (n == -2) {index--;// 左转一次相当于右转3次if (index == -1) {index = 3;}} else {// 前进n步,只要此方向上不包含障碍点while (n-- > 0 && !set.contains((x+directions[index][0])+"-"+(y+directions[index][1]))) {x += directions[index][0];y += directions[index][1];}}max = Math.max(max, x*x+y*y);}return max;
}

03 小结

算法专题目前已连续日更超过六个月,算法题文章205+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。

以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!

转载于:https://www.cnblogs.com/xiaochuan94/p/10873500.html

LeetCode.874-走路机器人模拟(Walking Robot Simulation)相关推荐

  1. [leetcode] 874. 行走机器人模拟(周赛)

    874. 行走机器人模拟 模拟 描述方向时有个技巧:int[][] dx = {{0, 1}, {1, 0}, {0, -1}, {-1, 0}}; 分别存储机器人向上.右.下.左走时,坐标应该如何变 ...

  2. C#LeetCode刷题之#874-模拟行走机器人​​​​​​​(Walking Robot Simulation)

    问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/4038 访问. 机器人在一个无限大小的网格上行走,从点 (0, 0 ...

  3. Leetcode 874. Walking Robot Simulation

    文章作者:Tyan 博客:noahsnail.com  |  CSDN  |  简书 1. Description 2. Solution class Solution { public:int ro ...

  4. LeetCode 874 题解

    874. Walking Robot Simulation 题目大意:二维空间,从原点出发 ,4个方向,走, 路上有障碍,有障碍的地方不能走. 解题思路:模拟 #define mp make_pair ...

  5. 机器人视觉系统(Robot Vision)简介

    机器人视觉系统(Robot Vision)简介 机器视觉系统的组成 机器视觉系统是指用计算机来实现人的视觉功能,也就是用计算机来实现对客观 的三维世界的识别.按现在的理解,人类视觉系统的感受部分是视网 ...

  6. OpenAI开源机器人模拟Python库mujoco-py:可高效处理并行模拟

    OpenAI 宣布开源一个高性能的 Python 库,它可用于使用 MuJoCo 引擎(在上年的机器人研究中开发出来)的机器人模拟. 代码:https://github.com/openai/mujo ...

  7. 新型机器人模拟蜻蜓飞行可以乱真!

    可以乱真!新型机器人模拟蜻蜓飞行 http://www.bjscivid.org/html/2013/experiment_0405/14682.html 转载于:https://www.cnblog ...

  8. 如何使用UR机器人模拟软件URsim

    如何使用UR机器人模拟软件URsim 机器人软件适用版本:Polyscope v1.3及以上 适用机器人:UR3.UR5.UR10 由于优傲机器人的系统是基于Linux核心开发的,模拟软体URsim也 ...

  9. 【Unity新闻】如何使用Unity进行机器人模拟? | AR/VR全球需求率激增1400%

    洪流学堂,让你快人几步. 我们一起看看上周Unity有什么大事情发生吧! 如何使用Unity进行机器人模拟? 机器人开发工作流程依赖于模拟进行测试和培训,Unity展示了机器人专家如何使用Unity来 ...

最新文章

  1. 10个凭证类型的速记
  2. python 判断类是否存在某个属性或方法
  3. jmeter --- 基于InfluxDBGrafana的JMeter实时性能测试数据的监控和展示
  4. 苹果cms v8模板 高仿爱奇艺带PC+手机模板
  5. 【算法】算法 动态规划 背包问题
  6. ASP.NET MVC资源汇总(本文不断更新)
  7. 37 岁学编程,发现第一个 Bug,创造商业编程语言 | 人物志
  8. pythonflask开发web网页编辑_总结Python+Flask+MysqL的web建设技术过程
  9. 2018双十一苏宁20+篇技术干货全整理
  10. java paint方法_在Java中,为了使paint()方法执行,以下各项中,()是最佳的调用方法
  11. 面向终端计算机网络的应用原理,山东科技大学计算机网络原理及应用复习提纲.doc...
  12. Gephi教程实战:从入门到精通——3
  13. 大数据和云计算技术的就业前景
  14. 强网杯2022 pwn 赛题解析——yakacmp
  15. 分布式异步任务神器-Celery
  16. python勾股定理、0-30_求助python大神,显示Process finished with exit code 0.
  17. HASH查找算法—JAVA实现
  18. 秋枫学习笔记-原创文章整理
  19. Kotlin Parcelize注解 即kotlin-android-extensions抛弃之后
  20. 循环,100遍“好好学习,天天向上”两种方法。

热门文章

  1. springcloud 的系统预热及预处理
  2. Redis数据结构之Geospatial
  3. R统计绘图-随机森林分类分析及物种丰度差异检验组合图
  4. 惊呆了,看华为技术专家的500页微服务架构笔记,感觉我格局太小
  5. 网易云课堂吴恩达Andrew Ng深度学习笔记(四)
  6. NERDTree插件安装和使用
  7. X-Plane飞行模拟资源整理一
  8. android 驾考软件开发,安卓模拟驾考游戏软件
  9. meri oracle view_MGMT_VIEW 用户的功能与作用
  10. 群签名方案-CS97