坐标移动

坐标移动

http://www.nowcoder.com/questionTerminal/119bcca3befb405fbe58abe9c532eb29

#include <stdio.h>
#include <string.h>
int x = 0, y = 0;
void like(char* str)
{
    int num = strlen(str);
    if (num > 3 || num <= 1)
        return;
    else
    {
        if ((str[0] == 'A' && str[1] >= '0' && str[1] <= '9' && str[2] == 0) ||
            (str[0] == 'A' && str[1] >= '0' && str[1] <= '9' && str[2] >= '0' && str[2] <= '9'))
        {
            if (str[2])
                x = x - ((str[1] - '0') * 10 + str[2] - '0');
            else
                x = x - str[1] + '0';
        }

        if ((str[0] == 'D' && str[1] >= '0' && str[1] <= '9' && str[2] == 0) ||
            (str[0] == 'D' && str[1] >= '0' && str[1] <= '9' && str[2] >= '0' && str[2] <= '9'))
        {
            if (str[2])
                x = x + ((str[1] - '0') * 10 + str[2] - '0');
            else
                x = x + str[1] - '0';
        }

        if ((str[0] == 'S' && str[1] >= '0' && str[1] <= '9' && str[2] == 0) ||
            (str[0] == 'S' && str[1] >= '0' && str[1] <= '9' && str[2] >= '0' && str[2] <= '9'))
        {
            if (str[2])
                y = y - ((str[1] - '0') * 10 + str[2] - '0');
            else
                y = y - str[1] + '0';
        }

        if ((str[0] == 'W' && str[1] >= '0' && str[1] <= '9' && str[2] == 0) ||
            (str[0] == 'W' && str[1] >= '0' && str[1] <= '9' && str[2] >= '0' && str[2] <= '9'))
        {
            if (str[2])
                y = y + ((str[1] - '0') * 10 + str[2] - '0');
            else
                y = y + str[1] - '0';
        }
    }
}
int main(void)
{
    char str[10000];
    char str1[1000];
    while (scanf("%s", str) != EOF)
    {
        x = 0; y = 0;
        int num = strlen(str);
        int j = 0;
        for (int i = 0; i < num; i++)
        {
            if (str[i] == ';')
            {
                str1[j] = 0;
                like(str1);
                j = 0;
                continue;
            }
            str1[j] = str[i];
            j++;
        }
        printf("%d,%d\r\n", x, y);
    }
 
    return 0;
}

全部评论
复制到一个数组,不断复制,然后处理,
点赞 回复 分享
发布于 2021-08-05 08:08

相关推荐

totoroyyw:千年老妖😂
投递华为等公司10个岗位
点赞 评论 收藏
分享
11-01 08:48
门头沟学院 C++
伤心的候选人在吵架:佬你不要的,能不能拿户口本证明过户给我。。球球了
点赞 评论 收藏
分享
8 1 评论
分享
牛客网
牛客企业服务