Movimiento de coordenadas de preguntas avanzadas en lenguaje C
Desarrolle una herramienta de cálculo de coordenadas, A significa moverse hacia la izquierda, D significa moverse hacia la derecha, W significa moverse hacia arriba y S significa moverse hacia abajo. El punto (0,0) comienza a moverse, lee algunas coordenadas de la cadena de entrada y envía el resultado de entrada final al archivo de salida.
Entrada
A10; S20; W10; D30; X; A1A; B10A11 ;; A10;
salida
10, -10
#include<stdio.h>
int main(){
int x = 0, y = 0;
char ch[5000];
scanf("%s",ch);
for (int i = 0; ch[i] != '\0'; ++i){
if (ch[i] == 'A'){
if ((ch[i + 1] >= 0 && ch[i + 1] <= '9') && (ch[i + 2] >= 0 && ch[i + 2] <= '9')){
//移2位数
x = x - (ch[i + 1] - 48) * 10 - (ch[i + 2] - 48);
if (ch[i+3] != ';'){
//即输入格式不正确,跳过错误格式,到下一个正确格式中,下同
x = x + (ch[i + 1] - 48) * 10 + (ch[i + 2] - 48);
}
i = i + 3;
}
else if (ch[i + 1] >= 0 && ch[i + 1] <= '9'){
//移1位数
x = x - (ch[i + 1] - 48);
if (ch[i+2] != ';'){
x = x + (ch[i + 1] - 48);
}
i = i + 2;
}
else {
while (ch[i] != ';'){
i++;
}
}
}
else if (ch[i] == 'D'){
if ((ch[i + 1] >= 0 && ch[i + 1] <= '9') && (ch[i + 2] >= 0 && ch[i + 2] <= '9')){
x = x + (ch[i + 1] - 48) * 10 + (ch[i + 2] - 48);
if (ch[i+3] != ';'){
x = x - (ch[i + 1] - 48) * 10 - (ch[i + 2] - 48);
}
i = i + 3;
}
else if (ch[i + 1] >= 0 && ch[i + 1] <= '9'){
x = x + (ch[i + 1] - 48);
if (ch[i+2] != ';'){
x = x - (ch[i + 1] - 48);
}
i = i + 2;
}
else {
while (ch[i] != ';'){
i++;
}
}
}
else if (ch[i] == 'W'){
if ((ch[i + 1] >= 0 && ch[i + 1] <= '9') && (ch[i + 2] >= 0 && ch[i + 2] <= '9')){
y = y + (ch[i + 1] - 48) * 10 + (ch[i + 2] - 48);
if (ch[i+3] != ';'){
y = y - (ch[i + 1] - 48) * 10 - (ch[i + 2] - 48);
}
i = i + 3;
}
else if (ch[i + 1] >= 0 && ch[i + 1] <= '9'){
y = y + (ch[i + 1] - 48);
if (ch[i+2] != ';'){
y = y - (ch[i + 1] - 48);
}
i = i + 2;
}
else {
while (ch[i] != ';'){
i++;
}
}
}
else if (ch[i] == 'S'){
if ((ch[i + 1] >= 0 && ch[i + 1] <= '9') && (ch[i + 2] >= 0 && ch[i + 2] <= '9')){
y = y - (ch[i + 1] - 48) * 10 - (ch[i + 2] - 48);
if (ch[i+3] != ';'){
y = y + (ch[i + 1] - 48) * 10 + (ch[i + 2] - 48);
}
i = i + 3;
}
else if (ch[i + 1] >= 0 && ch[i + 1] <= '9'){
y = y - (ch[i + 1] - 48);
if (ch[i+2] != ';'){
y = y + (ch[i + 1] - 48);
}
i = i + 2;
}
else {
while (ch[i] != ';'){
i++;
}
}
}
else{
while (ch[i] != ';'){
//当方向不是A,B,C,D是,则跳过,跳到‘;’位置
i++;
}
}
}
printf("%d,%d\n",x,y);
return 0;
}
Resultado de la operación:
entrada
A10; S20; W10; D30; X; A1A; B10A11 ;; A10;
salida
10, -10