Java-NowCoder-坐标移动

论坛 期权论坛 编程之家     
选择匿名的用户   2021-6-2 16:26   1960   0

题目描述:开发一个坐标计算工具, 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

输入描述:一行字符串

输出描述:最终坐标,以,分隔

输入例子:A10;S20;W10;D30;X;A1A;B10A11;;A10;

输出例子:10,-10

import java.util.Scanner;

public class Main{

 public static void main(String[] args) {
  Scanner sc = new Scanner(System.in);
  String str = null;
  while(sc.hasNextLine()){
   str = sc.nextLine();
   String[] point = str.split(";");//以分号分隔,形成数组
   int x = 0;//横向
   int y = 0;//纵向
   
   for(int i = 0; i < point.length; i++){
    try{
     char ch = point[i].charAt(0);//前边移动的方向
     int index = Integer.parseInt(point[i].substring(1, point[i].length()));//后边的坐标
     if(ch == 'A'){//左
      x = x - index;
     }
     if(ch == 'S'){//下
      y = y - index;
     }
     if(ch == 'D'){//右
      x = x + index;
     }
     if(ch == 'W'){//上
      y = y + index;
     }
    }catch (Exception e) {
     //System.out.println("输入字符串错误");
     continue;
    }
    
   }
   System.out.println(x + "," + y);
  }
  
 }
}


分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:3875789
帖子:775174
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP