题解 | #坐标移动#

坐标移动

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

自己一开始想得复杂了,预期要靠考虑输入不对的情况,不如反过来仅考虑输入正确的情况。反过来考虑那么可能出现的case就更少了

还是太菜了,多看看吧!

#include <bits/stdc++.h>
using namespace std;

struct position {
    int x;
    int y;
    position(int _x, int _y): x(_x), y(_y) {}
};

void movePo(string s1) {
    position po = position(0,0);
    int lens1 = s1.size();
    //s2用来存储子串
    vector<string> s2;
    //统计子串长度
    int sublen = 0;
    for(int i = 0; i < lens1; i++) {
        if(s1[i] != ';') {
            sublen++;
            //结束本轮循环
            continue;
        }
        //获取子串,压入s2 vector向量组中
        s2.push_back(s1.substr(i-sublen,sublen));
        sublen = 0;
    }
    //先计算出某个方向移动的数值
    for(int i = 0; i < s2.size(); i++) {
        int posiNum = 0;
        if(s2[i].size() == 3 && s2[i][1] >= '0' && s2[i][1] <= '9' && s2[i][2] >= '0' && s2[i][2] <= '9') {
            posiNum = (s2[i][1] - '0') * 10 + (s2[i][2] - '0');
        }
        if(s2[i].size() == 2 && s2[i][1] >= '0' && s2[i][1] <= '9') {
            posiNum = s2[i][1] - '0';
        }
        if(s2[i].size() == 1) {
            posiNum = 0;
        }
    //确定移动的方向
    switch(s2[i][0]) {
        case 'A': po.x -= posiNum;
        break;
        case 'D': po.x += posiNum;
        break;
        case 'S': po.y -= posiNum;
        break;
        case 'W': po.y += posiNum;
        break;
        default:
            break;
        }

    }
    cout << po.x << "," << po.y <<endl;
}


int main() {
    string s;
    getline(cin, s);
    movePo(s);
    return 0;
}
全部评论

相关推荐

04-17 18:32
门头沟学院 Java
野猪不是猪🐗:他跟你一个学校,你要是进来之后待遇比他好,他受得了?
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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