华为机试之坐标移动

该博客介绍了华为机试中关于坐标移动的题目,要求处理合法的A/D/W/S坐标移动指令,从(0,0)开始并忽略非法坐标。解题思路包括使用String的split()方法分割输入,通过正则表达式筛选有效坐标,并用switch语句处理移动方向。常见的正则表达式如\s+用于匹配多个空格,[0-9]和[0-9]+用于检查数字长度。" 109137101,7937448,GCC优化对C代码的影响分析,"['C语言', '编译器优化', '汇编语言']
摘要由CSDN通过智能技术生成

1>题目描述

  • 开发一个坐标计算工具,
    A表示向左移动,D表示向右移动,W表示向上移动,S表示向下移动。从(0,0)点开始移动,从输入字符串里面读取一些坐标,并将最终输入结果输出到输出文件里面。

  • 输入:

    • 合法坐标为A(或者D或者W或者S) + 数字(两位以内)
    • 坐标之间以;分隔。
    • 非法坐标点需要进行丢弃。如AA10; A1A; % ; YAD; 等。
  • 下面是一个简单的例子 如:

     A10;S20;W10;D30;X;A1A;B10A11;;A10;
    
  • 处理过程:

     起点(0,0)
     
     +   A10   =  (-10,0)
     
     +   S20   =  (-10,-20)
     
     +   W10  =  (-10,-10)
     
     +   D30  =  (20,-10)
     
     +   x    =  无效
     
     +   A1A   =  无效
     
     +   B10A11   =  无效
     
     +  一个空 不影响
     
     +   A10  =  (10,-10)
     
     结果 (10, -10)
    
  • 注意请处理多组输入输出
    在这里插入图片描述

2>解法

  • 1、首先要将输入的字符串分类,这里使用String的split()方法分割《;》
  • 2、对于字符串数组的每一个字符串进行筛选
    • 1>字符串的长度必须是2或者3
    • 2>字符串除去第一个字符后剩下的字符必须全为数字
      • 这里利用了String的matches方法,利用正则表达式来区分
    • 3>根据字符串第一个字母使用switch进行区分对待
  • 3、使用两个变量来存储输出之后的数字
import java.util.*;
public class Main{
   
    public static void main(String[] args){
   
        Scanner scanner
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值