题解 | #坐标移动#

坐标移动

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

#include<iostream>
#include<vector>
#include<string>
using namespace std;
//坐标移动的函数接口
int Coordinate_Movement(string str) {
    int x = 0, y = 0; //初始化横纵坐标
    int len = str.size(); //获取字符串的总长度
    vector <string> vec; //用一个向量来存储分割后的多个子字符串
    //将字符串 str 按 ';' 分割成多个子字符串 substr,然后依次写入向量 vec 中
    int sublen = 0; //记录每个子字符串的长度
    for (int i = 0; i < len; i++) {
        if (str[i] != ';') {
            sublen++;
            continue;
        }
        vec.push_back(str.substr(i - sublen, sublen));
        sublen = 0;
    }
    //坐标移动,方向(左右上下) + 大小(-99~99)
    for (int i = 0; i < vec.size(); i++) {
        //确定坐标移动的大小,[-99,99]
        int num = 0; //(横或纵)坐标移动的大小
        //若字符串为三位有效位,则第二和第三位是坐标移动的大小
        if ((vec[i].size() == 3) && (vec[i][1] >= '0') && (vec[i][1] <= '9') &&
                (vec[i][2] >= '0') && (vec[i][2] <= '9')) {
            num = (vec[i][1] - '0') * 10 + (vec[i][2] - '0');
        }
        //若字符串为两位有效位,则第二位是坐标移动的大小
        if ((vec[i].size() == 2) && (vec[i][1] <= '9') && (vec[i][1] >= '0')) {
            num = (vec[i][1] - '0');
        }
        //若字符串为一位有效位,则无坐标移动
        if (vec[i].size() == 1) {
            num = 0;
        }
        //确定坐标移动的方向,左右上下
        switch (vec[i][0]) {
            case 'A':
                x -= num;
                break;
            case 'D':
                x += num;
                break;
            case 'S':
                y -= num;
                break;
            case 'W':
                y += num;
                break;
            default:
                break;
        }
    }
    cout << x << "," << y << endl;
    return 0;
}
//主函数
int main() {
    string str;
    while (cin >> str) {
        Coordinate_Movement(str);
    }
    return 0;
}

全部评论

相关推荐

不愿透露姓名的神秘牛友
11-29 12:19
点赞 评论 收藏
分享
我在朝九晚六双休的联想等你:如果我是你,身体素质好我会去参军,然后走士兵计划考研211只需要200多分。
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务