Java练习 SDUT-2585_机器人II

机器人II

Time Limit: 1000 ms Memory Limit: 65536 KiB

Problem Description

自从xiao_wu发明了只能向左转与向右转的机器人以后,热血沸腾的他又给机器人加了一个操作。假设机器人在二维坐标系的原点,一开始面向Y轴正方向(北N),现在给你一个仅由’L’,’R’,’M’的串,其中L表示向左转,R表示向右转,M表示向所面对的方向走一个单位的距离,试问经过操作过后,机器人的坐标和所面对的方向。

北(N),西(W),东(E),南(S)。

Input

第一行输入一个T(T<150),表示任务的个数
对于每个任务,输入一个串。(每个任务开始前机器人在原点,面向北(N),既Y轴正方向)
串长度不大于100

Output

对于每个任务,输出两个数表示机器人的坐标,一个字符表示机器人的面朝的方向。

Sample Input

2
LRMLL
LMRMMLLL

Sample Output

0 1 S
-1 2 E

可以用数组存储方向,R加,L减,具体看代码。

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner cin = new Scanner(System.in);
        int t,x,y,f,i;
        char s[] = {'N','E','S','W'};
        String q;
        t = cin.nextInt();
        while(t-->0)
        {
        	f = 0;
        	x = y = 0;
        	q = cin.next();
        	for(i=0;i<q.length();i++)
        	{
        		if(q.charAt(i)=='M')
        		{
        			if(f==0)
        				y++;
        			else if(f==2)
        				y--;
        			else if(f==1)
        				x++;
        			else if(f==3)
        				x--;
        		}
        		else if(q.charAt(i)=='R')
        		{
        			f++;
        			if(f>3)
        				f -= 4;
        		}
        		else if(q.charAt(i)=='L')
        		{
        			f--;
        			if(f<0)
        				f += 4;
        		}
        	}
        	System.out.printf("%d %d %c\n",x,y,s[f]);
        }
        cin.close();
    }
}
posted @   洛沐辰  阅读(360)  评论(0编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示