以下程序期望用户输入混合分数格式'whole_numbernumerator / denominator'并为各个变量赋值。
#include<iostream>
using namespace std;
int main()
{
int whole, numerator, denominator;
cout << "Input format: i<space>n/d" << endl;
cin >> whole;
cin.ignore(1000, ' ');
cin >> numerator;
cin.ignore(1000, '/');
cin >> denominator;
cout << whole << endl;
cout << numerator << endl;
cout << denominator << endl;
return 0;
}
输入1:
123 345/678
的输出1:
123个
345个
678个
的输入2 :
1111111111 1111111111/1111111111
的输出2:
1111111111个
1111111111个
1111111111个
的输入3:
2222222222 2222222222/222222222
的输出3:
2147483647个
0
0
我无法弄清楚为什么程序不适用于Input3。
答案 0 :(得分:3)
您正在溢出32位整数的最大值(2 ^ 31-1~ = 2.147b)。一旦发生这种情况,cin
在您清除标记之前无法正常工作。您应该检查错误,但短期解决方案是使您的号码无符号,或使用64位,如int64_t
。您也不需要忽略空格,因为cin
默认会跳过它。
您可以实现类似here的内容以确保有效输入,但需要根据您的特定输入格式进行定制。也许将三个封装成单个类型,并使用重载运算符输入每个格式,这样可以使语法更合适,因此您可以使用age
对象替换示例中的MixedNumber
。 / p>
我会看到类似这样的通用方法:
template <typename T> //any type will work
void getValidInput (T &var, std::string prompt = "Input: ") {
while ((std::cout << prompt) && !(std::cin >> var)) { //if cin fails...
std::cin.clear(); //clear flag and discard bad input
std::cin.ignore (std::numeric_limits<std::streamsize>::max(), '\n');
std::cout << "Invalid input; please re-enter.\n"; //let the user know
}
}
然后你可以让你的程序如下:
struct MixedNumber { //a data structure, so it's like using plain variables
int64_t whole;
int64_t numerator;
int64_t denominator;
};
std::istream &operator>> (std::istream &in, MixedNumber &num) { //so cin works
in >> num.whole >> num.numerator;
in.ignore(); //yes, you could enforce the format a bit more
in >> num.denominator;
return in;
}
int main() {
MixedNumber num; //easy to "make" a mixed number, a constructor works well too
getValidInput (num, "Input format: i<space>n/d: ");
std::cout << num.whole << '\n' << num.numerator << '\n' << num.denominator;
}