Leetcode 1041. 困于环中的机器人

1.题目基本信息

1.1.题目描述

在无限的平面上,机器人最初位于 (0, 0) 处,面朝北方。注意:

  • 北方向 是y轴的正方向。

  • 南方向 是y轴的负方向。

  • 东方向 是x轴的正方向。

  • 西方向 是x轴的负方向。

    机器人可以接受下列三条指令之一:

  • "G":直走 1 个单位

  • "L":左转 90 度

  • "R":右转 90 度

    机器人按顺序执行指令 instructions,并一直重复它们。

只有在平面中存在环使得机器人永远无法离开时,返回 true。否则,返回 false。

1.2.题目地址

https://leetcode.cn/problems/robot-bounded-in-circle/description

2.解题方法

2.1.解题思路

模拟:只有一种情况,机器人无限循环下不能到达起点,即为假如开始是向北走,那么一次循环后,机器人不在起点并且方向还是向北。其余情况经过有限次循环,都能到达起点。

2.2.解题步骤

第一步,构建方向数组并初始化当前的方向和位置

第二步,遍历步骤,并更新当前的方向和位置

第三步,根据一次循环后的位置和方向判断无限循环下是否能到达起点

3.解题代码

Python代码

python 复制代码
class Solution:
    # 模拟:只有一种情况,机器人无限循环下不能到达起点,即为假如开始是向北走,那么一次循环后,机器人不在起点并且方向还是向北。其余情况经过有限次循环,都能到达起点。
    def isRobotBounded(self, instructions: str) -> bool:
        # 第一步,构建方向数组并初始化当前的方向和位置
        directions=[[0,1],[-1,0],[0,-1],[1,0]]
        directIndex=0
        x,y=0,0
        # 第二步,遍历步骤,并更新当前的方向和位置
        for c in instructions:
            if c=="G":
                x+=directions[directIndex][0]
                y+=directions[directIndex][1]
            elif c=="L":
                directIndex=(directIndex+1)%4
            elif c=="R":
                directIndex=(directIndex-1)%4
        # 第三步,根据一次循环后的位置和方向判断无限循环下是否能到达起点
        return False if directIndex==0 and (x!=0 or y!=0) else True

C++代码

cpp 复制代码
class Solution {
public:
    bool isRobotBounded(string instructions) {
        vector<vector<int>> directions={{0,1},{-1,0},{0,-1},{1,0}};
        int directIndex=0;
        int x=0,y=0;
        for(char c:instructions){
            if(c=='G'){
                x+=directions[directIndex][0];
                y+=directions[directIndex][1];
            }else if(c=='L'){
                directIndex=(directIndex+1)%4;
            }else if(c=='R'){
                directIndex=(directIndex-1+4)%4;
            }
        }
        return directIndex==0 && (x!=0 || y!=0) ? false : true;
    }
};

4.执行结果

相关推荐
gfdhy3 小时前
【c++】哈希算法深度解析:实现、核心作用与工业级应用
c语言·开发语言·c++·算法·密码学·哈希算法·哈希
百***06013 小时前
SpringMVC 请求参数接收
前端·javascript·算法
m0_650108243 小时前
PaLM-E:具身智能的多模态语言模型新范式
论文阅读·人工智能·机器人·具身智能·多模态大语言模型·palm-e·大模型驱动
一个不知名程序员www4 小时前
算法学习入门---vector(C++)
c++·算法
云飞云共享云桌面4 小时前
无需配置传统电脑——智能装备工厂10个SolidWorks共享一台工作站
运维·服务器·前端·网络·算法·电脑
福尔摩斯张4 小时前
《C 语言指针从入门到精通:全面笔记 + 实战习题深度解析》(超详细)
linux·运维·服务器·c语言·开发语言·c++·算法
橘颂TA4 小时前
【剑斩OFFER】算法的暴力美学——两整数之和
算法·leetcode·职场和发展
Dream it possible!5 小时前
LeetCode 面试经典 150_二叉搜索树_二叉搜索树的最小绝对差(85_530_C++_简单)
c++·leetcode·面试
xxxxxxllllllshi5 小时前
【LeetCode Hot100----14-贪心算法(01-05),包含多种方法,详细思路与代码,让你一篇文章看懂所有!】
java·数据结构·算法·leetcode·贪心算法
前端小L5 小时前
图论专题(二十二):并查集的“逻辑审判”——判断「等式方程的可满足性」
算法·矩阵·深度优先·图论·宽度优先