题解 | #坐标移动#

坐标移动

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

#include<iostream>
#include<string>
using namespace std;
int main()
{
    string str;
    char flag = ' ';
    while(cin>>str)
    {
        int raw=0, col=0;
        int len = str.length();
        int pos = 0;
        int num = 0;
        while(pos<len)
        {
            if(str[pos] == ';')
            {
                pos++;
                continue;
            }
            if(str[pos]=='A'||str[pos]=='S'||str[pos]=='W'||str[pos]=='D')
            {
                flag = str[pos];
                pos++;
                if(isdigit(str[pos]))
                {
                    while(str[pos] != ';')
                    {
                        if(isdigit(str[pos]))
                        {
                            num = num*10+str[pos]-'0';
                            pos++;
                        }
                        else
                        {
                             while(str[pos] != ';')
                             {
                                 pos++;
                             }
                            num = 0;
                            flag = ' ';
                            break;
                        }
                    }
                }
                switch (flag)
                {
                    case 'A':
                        {
                            raw -= num;
                            num = 0;
                            flag = ' ';
                            break;
                        }
                    case 'W':
                        {
                            col += num;
                            num = 0;
                            flag = ' ';
                            break;
                        }
                    case 'S':
                        {
                            col -= num;
                            num = 0;
                            flag = ' ';
                            break;
                        }
                    case 'D':
                        {
                            raw += num;
                            num = 0;
                            flag = ' ';
                            break;
                        }
                    case ' ':
                        break;
                }
            }
            else
            {
                while(str[pos] != ';')
                {
                    pos++;
                }
                num = 0;
                flag = ' ';
            }
            pos++; 
        }
        cout<<raw<<","<<col<<endl;
    }
    return 0;
}
全部评论

相关推荐

屌丝逆袭咸鱼计划:心态摆好,man,晚点找早点找到最后都是为了提升自己好进正职,努力提升自己才是最关键的😤难道说现在找不到找的太晚了就炸了可以鸡鸡了吗😤早实习晚实习不都是为了以后多积累,大四学长有的秋招进的也不妨碍有的春招进,人生就这样
点赞 评论 收藏
分享
今天 12:20
门头沟学院 运营
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务