解题3(CoordinateCalculate)
题目描述
开发一个坐标计算工具, 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
代码如下:
package com.yzh.hehe; import java.util.ArrayList;
import java.util.List;
import java.util.Scanner; public class CoordinateCalculate { public static void main(String[] args) {
Scanner scanner=new Scanner(System.in);
while (scanner.hasNext()) {
String coordinate=scanner.nextLine();
calculateCoordinate(coordinate);
}
scanner.close();
} //根据输入的坐标字符串,移动坐标,得到最后结果
private static void calculateCoordinate(String coordinate) {
String[] coorArr=coordinate.split(";");
List<String>list=new ArrayList<String>(200);
for (String string : coorArr) {
if (isCoordinate(string)) {
list.add(string);
}
}
CoordinateOBJ coordinateOBJ=new CoordinateOBJ(0,0);
for (String string : list) {
moveCoordinate(coordinateOBJ, string);
}
System.out.println(coordinateOBJ.getX()+","+coordinateOBJ.getY());
}
//判断坐标是否合法(合法坐标为A(或者D或者W或者S) + 数字(两位以内))
private static boolean isCoordinate(String coordinate) { if(coordinate==null ){
return false;
}
coordinate=coordinate.trim();
if("".equals(coordinate) ){
return false;
}
if (!(coordinate.length()>1&&coordinate.length()<4)) {
return false;
}
char c=coordinate.charAt(0);
if (!(c=='W'||c=='S'||c=='A'||c=='D')) {
return false;
}
//正则表达式判断
if (!(coordinate.substring(1).matches("[0-9]+"))) {
return false;
}
//效果同上
// if (!(coordinate.charAt(1)<='9'&&coordinate.charAt(1)>='0')) {
// return false;
// }
// if (coordinate.length()==2) {
// return true;
// }
// if (!(coordinate.charAt(2)<='9'&&coordinate.charAt(2)>='0')) {
// return false;
// }
return true;
}
//一次移动坐标
private static void moveCoordinate(CoordinateOBJ coordinate,String move) {
char c=move.charAt(0);
int value=Integer.valueOf(move.substring(1));
if(c=='A'){
coordinate.setX(coordinate.getX()-value);
}else if (c=='W') {
coordinate.setY(coordinate.getY()+value);
}else if (c=='S') {
coordinate.setY(coordinate.getY()-value);
}else {
coordinate.setX(coordinate.getX()+value);
}
} }
class CoordinateOBJ{
private int x;
private int y;
protected CoordinateOBJ(int x,int y){
this.x=x;
this.y=y;
} public void setX(int x) {
this.x=x;
}
public void setY(int y) {
this.y=y;
}
public int getX() {
return this.x;
}
public int getY() {
return this.y;
}
}
解题3(CoordinateCalculate)的更多相关文章
- SCNU ACM 2016新生赛决赛 解题报告
新生初赛题目.解题思路.参考代码一览 A. 拒绝虐狗 Problem Description CZJ 去排队打饭的时候看到前面有几对情侣秀恩爱,作为单身狗的 CZJ 表示很难受. 现在给出一个字符串代 ...
- SCNU ACM 2016新生赛初赛 解题报告
新生初赛题目.解题思路.参考代码一览 1001. 无聊的日常 Problem Description 两位小朋友小A和小B无聊时玩了个游戏,在限定时间内说出一排数字,那边说出的数大就赢,你的工作是帮他 ...
- HDU 3791二叉搜索树解题(解题报告)
1.题目地址: http://acm.hdu.edu.cn/showproblem.php?pid=3791 2.参考解题 http://blog.csdn.net/u013447865/articl ...
- 【BZOJ1700】[Usaco2007 Jan]Problem Solving 解题 动态规划
[BZOJ1700][Usaco2007 Jan]Problem Solving 解题 Description 过去的日子里,农夫John的牛没有任何题目. 可是现在他们有题目,有很多的题目. 精确地 ...
- CH Round #56 - 国庆节欢乐赛解题报告
最近CH上的比赛很多,在此会全部写出解题报告,与大家交流一下解题方法与技巧. T1 魔幻森林 描述 Cortana来到了一片魔幻森林,这片森林可以被视作一个N*M的矩阵,矩阵中的每个位置上都长着一棵树 ...
- wechall.net/stegano 解题心得
/* 转载请注明出处:http://www.cnblogs.com/Martinium/p/wechall_stegano.html */ 最近迷上了 www.wechall.net 网站,里面都是些 ...
- Mountains(CVTE面试题)解题报告
题目大意: 用一个数组代表群山的高度.高度大的地方代表山峰,小的地方代表山谷.山谷可以容水.假设有一天下了大雨,求群山中总共可以容纳多少水? 如图所示情况,a代表该数组,总共可以容纳5个水. 解题思路 ...
- timus 1180. Stone Game 解题报告
1.题目: 1180. Stone Game Time limit: 1.0 secondMemory limit: 64 MB Two Nikifors play a funny game. The ...
- timus 1175. Strange Sequence 解题报告
1.题目描述: 1175. Strange Sequence Time limit: 1.0 secondMemory limit: 2 MB You have been asked to disco ...
随机推荐
- ROS学习手记 - 8 编写ROS的Publisher and Subscriber
上一节我们完成了 message & srv 文件的创建和加入编译,这次我们要玩简单的Publisher 和 Subscriber 要玩 Publisher 和 Subscriber, 需要具 ...
- 【SQL函数】我知道你想group_concat和count一起用,比如不同组合的人数?
0.背景 前几天复习了一下MySQL函数,知道一个group_concat函数很好用,但一直没实际用过.今天碰到一个问题,把我问懵逼了. 1.实例 假设有一张用户购买产品的增量表order_list, ...
- 10.Appium驱动app报错
1.首先手机使用usb连接电脑端接受控制 2.打开appium,配置Desired Capabilities 参数: Appium驱动打开微信App 参数配置如下: start session 报错: ...
- Yii Framework隐藏index.php文件的步骤
Yii Framework隐藏index.php文件的步骤 作者:feebas 发布于:2012-4-23 13:36 Monday 分类:Yii Framework 1.开启apache的mod_r ...
- .Net 上传文件和下载文件
一.上传文件 1.普通的form表单提交 注意点: 请求方式必须为Post. form表单里必须设置enctype属性(enctype = "multipart/form-data" ...
- Retrofit添加自定义转换器
Retrofit2开始支持多种 Converter 并存,在之前,如果你遇到这种情况:一个 API 请求返回的结果需要通过 JSON 反序列化,另一个 API 请求需要通过 proto 反序列化,唯一 ...
- redis 安装 ,sea 比较友好的一种
参考: https://blog.csdn.net/qq_26709459/article/details/80159468 redis 安装与配置 Remark: 请务必开放端口 6379 ,否则其 ...
- eclipse中jdk源码调试步骤
分析源码是学习一项技术内幕最有效的手段.由于正常的引入JAr包源码没法进行对源码打断点,想要深入了解源码不方便.下面就开始介绍源码调试的步骤. 1.在eclipse新建一个JAVA项目compare_ ...
- css样式表1
1内联样式表 和html联合使用,控制精确,但是可重用性差,冗余多. <p style="font-size:14px;"></p> <div sty ...
- linux下安装Tomcat7.0
1.下载安装文件:Download apache-tomcat-7.0.14.tar.gz 下载1 下载 2.输入命令解压文件:tar - zxvf apach ...