我有一个Fraction类,允许以c / d的形式输入分数。 我可以很好地输出和输入分数,但是当我使用我的自定义函数修改它们时,如下所示,它什么都不做。
我有以下重载>>和<<操作符:
ostream& operator<<(ostream &out, const Fraction &f)
{
char x = '/';
out << f.num;
out << x;
out << f.den;
return out;
}
istream& operator>>(istream &in, Fraction &r)
{
//in >> r;
int whole = 0, num, den = 1;
char next;
in >> num;
next = in.peek();
if(next == '+'){
in.get();
whole = num;
in >> num;
next = in.peek();
}
if(next == '/'){
in.get();
in >> den;
}
if(whole != 0){
num += (whole * den);
}
if(den == 0){
den = 1;
}
r.num = num;
r.den = den;
return in;
}
此外,我有一个函数,它使两个分数具有相同的公分母:
void setEqualDen(Fraction a, Fraction b){
int tempa = a.den;
int tempb = b.den;
a.den *= tempb;
b.den *= tempa;
a.num *= tempb;
b.num *= tempa;
}
然后我尝试在main中输出结果:
setEqualDen(Fa, Fb);
cout << "The fractions are " << Fa << " , " << Fb <<
endl;
这不起作用。是否有必要的步骤,例如双重重载&lt;&lt;和&gt;&gt;用C ++编写运算符,或者我的语法只是遗漏了什么?
答案 0 :(得分:2)
你想在函数定义中使用&
,因为你需要通过引用传递,因为你正在修改你的'分数。
void setEqualDen(Fraction &a, Fraction &b){
int tempa = a.den;
int tempb = b.den;
a.den *= tempb;
b.den *= tempa;
a.num *= tempb;
b.num *= tempa;
}
答案 1 :(得分:0)
您需要检查输入错误并跳过空格。我建议使用临时包含第一个数字,因为它可以是整数或分子。差异化需要在&#39; /&#39;之后进行。被检测到。
std::istream& operator>>(std::istream& inp, Fraction& f)
{
int temp = 0;
f.num = 0;
f.den = 1;
inp >> temp; // Could be whole number or numerator.
if (inp)
{
int whole = temp;
int numerator = 0;
inp >> numerator;
if (!inp)
{
// Let's assume that the input failed because of the '/' symbol.
numerator = temp;
whole = 0;
inp.clear();
}
else
{
inp.ignore(1000, '/'); // Skip over the '/'
}
int denominator = 1;
inp >> denominator;
if (denominator == 0) denominator = 1;
numerator += whole * denominator;
f.num = numerator;
f.den = denominator;
}
return inp;
}