leetcode10-困于环中的机器人

题目链接:

https://leetcode.cn/problems/robot-bounded-in-circle/description/?envType=study-plan-v2&envId=programming-skills

思路:

首先,题目要寻找的是成环的情况。

1.如果经历一次指令后的方向仍为北方,要使得机器人循环困住,必须让机器人回到原点

2.如果经历一次指令后的方向不是北方,那么最多重复四次又会回到面朝北方,这种情况下机器人虽然不会回到原点,但是也一直都被环困住。 

代码采用了常用的二维平面的向量坐标写法

代码:

class Solution {
    public boolean isRobotBounded(String instructions) {
        //记录 0 1 2 3
        //    北东南西 坐标向量写法
        int [][] res = {
            {0,1},{1,0},{0,-1},{-1,0}
        };
        int n = instructions.length();
        int x = 0,y = 0;//记录坐标
        int faceDirect = 0;//记录朝向 一开始为0 表示指向北
        for(int i = 0;i<n;i++) {
            //直走命令
            if(instructions.charAt(i)=='G') {
                x+=res[faceDirect][0];
                y+=res[faceDirect][1];
            }
            //左转命令
            else if(instructions.charAt(i)=='L') {
                faceDirect = (faceDirect+3)%4;
                
            }
            //右转命令
            else if(instructions.charAt(i)=='R') {
                faceDirect = (faceDirect+1)%4;
            }
        }
        if( (x==0 && y==0)|| faceDirect!=0)
            return true;
        return false;
    }
}

相关推荐

  1. leetcode10-机器人

    2024-01-08 07:12:03       61 阅读
  2. Leetcode-1041. 机器人

    2024-01-08 07:12:03       49 阅读
  3. 机器人

    2024-01-08 07:12:03       57 阅读
  4. 机器学习LeetCode

    2024-01-08 07:12:03       24 阅读
  5. leetcode 141 判断链表是否存在

    2024-01-08 07:12:03       55 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-08 07:12:03       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-08 07:12:03       106 阅读
  3. 在Django里面运行非项目文件

    2024-01-08 07:12:03       87 阅读
  4. Python语言-面向对象

    2024-01-08 07:12:03       96 阅读

热门阅读

  1. UNION 和 UNION ALL

    2024-01-08 07:12:03       56 阅读
  2. NodeJs 第六章 简单了解数据库(MySql)

    2024-01-08 07:12:03       62 阅读
  3. 云原生和Kubernetes如何简化应用程序开发

    2024-01-08 07:12:03       55 阅读
  4. 游戏美术的技与艺

    2024-01-08 07:12:03       57 阅读