#include<iostream> #include<string> using namespace std; bool isNum(string s) { for (auto x : s) //从传过来的字符串继承一个同样的字符串 { if (!isdigit(x)) //如果不是数字,返回false return false; } return true; //否则返回true } int main() { string s; pair<int, int> p(0, 0);//定义一个数对,名为p,初始值为(0,0) while (getline(cin, s, ";")) { if (s.empty()) continue; //如果本次取到的字符串为空,则直接进行下一次截取 string s1 = s.substr(1); //把本次取到的字符串第二位到末尾的字符取出 if (isNum(s1)) { switch (s[0]) { case'A': p.first -= stoi(s1);//stoi函数将字符串转化为10进制数字 break; case'D': p.first += stoi(s1); break; case'W': p.second += stoi(s1); break; case'S': p.second -= stoi(s1); break; default: break; } } } cout << p.first << "," << p.second; return 0; }无法运行
时间: 2023-06-17 07:07:13 浏览: 73
这段代码可能存在以下问题:
1. 头文件和命名空间使用不规范。头文件和命名空间需要在代码的最开始声明,你的代码中包含在中间位置,这会导致编译错误。
2. `getline()` 函数的使用不规范。`getline()` 函数的第三个参数应该是一个字符,用于分隔输入流。你的代码中把分隔符写成了 `";"`,但是这样会导致输入流无法正常分隔,因为输入流中可能包含 `";"`。通常情况下,我们会使用空格或换行符作为分隔符。
3. `isNum()` 函数的实现不完整。该函数只考虑了字符串中是否全部由数字构成,但没有考虑字符串中是否可能出现负号或小数点等非数字字符。如果你的字符串中包含这些非数字字符,那么 `stoi()` 函数会抛出异常,导致程序崩溃。
4. `stoi()` 函数的使用不规范。`stoi()` 函数将字符串转换为整数类型,但如果字符串中包含非数字字符,那么这个函数会抛出异常。你的代码中没有处理这些异常,这会导致程序运行错误。
你可以尝试修改代码,解决这些问题。以下是一个可能的修改方案:
阅读全文