题目:
开发一个坐标计算工具, A表示向左移动,D表示向右移动,W表示向上移动,S表示向下移动。从(0,0)点开始移动,从输入字符串里面读取一些坐标,并将最终输入结果输出到输出文件里面。
输入:
合法坐标为A(或者D或者W或者S) + 数字(两位以内)
坐标之间以;分隔。非法坐标点需要进行丢弃。
输入描述:
一行字符串
输出描述:
最终坐标,以逗号分隔
思路:
采用HashMap实现对坐标的操作,运用正则表达式去过滤不合法字符
import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;
public class Main{
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
Map<Character,Integer> map = new HashMap<Character,Integer>();
while(sc.hasNext()){
String s = sc.nextLine();
int x = 0;
int y = 0;
String[] sArray = s.split(";");
String res = "[AWSD][0-9]{1,2}";
for(int i = 0;i < sArray.length;i++){
if(sArray[i].matches(res)){
map.put(sArray[i].charAt(0),map.getOrDefault(sArray[i].charAt(0),0)+Integer.valueOf(sArray[i].substring(1)));
}
}
x = x - map.get('A') + map.get('D');
y = y - map.get('S') + map.get('W');
System.out.println(x+","+y);
map.clear();
}
}
}