描述
开发一个坐标计算工具, 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)
数据范围:每组输入的字符串长度满足
1≤n≤10000坐标保证满足 −2^31≤x,y≤2 ^31−1,且数字部分仅含正数.
输入描述:
一行字符串
输出描述:
最终坐标,以逗号分隔
示例1
A10;S20;W10;D30;X;A1A;B10A11;;A10;
10,-10
示例2
ABC;AKL;DA1;
0,0
循环遍历
从头到尾遍历整个字符串,如果遍历到字符’W’,‘S’,‘A’,'D’就判断后面的字符,如果是数字则对字符进行处理,将他转换为数字,否则就将计数清零。
#include <stdio.h>
#include <string.h>
int main() {
int flage = 0, temp = 1, num = 0;
int x = 0, y = 0, i;
char s[10000], direction;
scanf("%s", s);
for (i = 0; i < strlen(s); i++) {
if (s[i] == 'W' || s[i] == 'S' || s[i] == 'A' || s[i] == 'D') {
// printf("%c ",s[i]);
direction = s[i];
flage = 1;
temp = 1;
}else {
while(s[i]!=';')
{
i++;
}
}
if (flage == 1) {
i++;
flage = 0;
num = 0;
while (s[i] != ';' && s[i] != '\0') {
if ((s[i] >= '0' && s[i] <= '9') && temp == 1) {
num *= 10;
num += s[i] - '0';
i++;
} else {
temp = 0;
i++;
num = 0;
}
}
if (direction == 'W') {
y += num;
} else if (direction == 'S') {
y -= num;
} else if (direction == 'A') {
x -= num;
} else if (direction == 'D') {
x += num;
}
}
}
printf("%d,%d", x, y);
}