leetcode10-困于环中的机器人

题目链接:

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

思路:

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

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

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

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

代码:

java 复制代码
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;
    }
}
相关推荐
李慕婉学姐15 小时前
【开题答辩过程】以《基于Java的周边游优选推荐网站的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·开发语言
计算机毕设指导615 小时前
基于微信小程序民宿预订管理系统【源码文末联系】
java·spring boot·mysql·微信小程序·小程序·tomcat·maven
我命由我1234515 小时前
Kotlin 开发 - Kotlin Lambda 表达式返回值
android·java·开发语言·java-ee·kotlin·android studio·android-studio
Knight_AL15 小时前
从单例模式说起:Java 常见设计模式的理解与实践
java·单例模式·设计模式
a努力。15 小时前
中国电网Java面试被问:Dubbo的服务目录和路由链实现
java·开发语言·jvm·后端·面试·职场和发展·dubbo
爬山算法15 小时前
Hibernate(42)在Hibernate中如何实现分页?
java·后端·hibernate
不平衡的叉叉树15 小时前
我们遇到了正则表达式的灾难性回溯问题
java·正则表达式
wangkay8815 小时前
【Java 转运营】Day05:抖音新号起号:对标账号运营全指南
java·新媒体运营
大飞哥~BigFei15 小时前
新版chrome浏览器安全限制及解决办法
java·前端·chrome·安全·跨域