我正在尝试学习面向对象的编程并制作简单的分数计算器,而不是可以添加或减去任意数量的函数,并将答案写成一个简化的分数。
示例:input = 3/2 + 4 / 8 ,输出= 2
我正在尝试重载运算符以实现此目的。
因此在程序中,我正在尝试开发输入,其中包含由运算符分隔的分数组成的表达式' +'或' - '。
表达式中的分数数是任意的。
以下6行中的每一行都是有效输入表达式的示例:
1/2 + 3/4
1/2 -5/7+3/5
355/113
3 /9-21/ -7
4/7-5/-8
-2/-3+7/5
作为输入给出的分数的分子和/或分母可能是负的。 我试图让输入由单行上的单个表达式组成,并且应该通过检测文件末尾来检测输入的结尾。
我的不完整分数类在我的源文件中定义:
#include <iostream>
using namespace std;
#include "Fraction.h"
#include <stdexcept>
class Fraction
{
public:
Fraction::Fraction(int a, int b);
int find_gcd(int n1, int n2);
void reduce_fraction(int *nump, int *denomp)
{
int gcd;
gcd = find_gcd(*nump, *denomp);
*nump = *nump / gcd;
*denomp = *denomp / gcd;
if ((*denomp<0 && *nump < 0 ))
{
*denomp*=-1;
*nump*=-1;
}
else if (*denomp < 0 && *nump >0){
*denomp*=-1;
}
if ( *denomp ==0) {
throw invalid_argument( "Error: zero denominator" );
}
}
Fraction& Fraction::operator+(const Fraction& n) {
int denom = *denomp * n.denom;
int numera = (*nump * n.numera) + (n.denom * n.nump);
return Fraction(numera,denom);
}
Fraction& Fraction::operator-(const Fraction& n) {
int denom = *denomp * n.denom;
int numera = (*nump * n.numera) - (n.denom* n.nump);
return Fraction(numera, denom);
}
friend ostream& operator<<(ostream &os, Fraction& n)
{
if (n.numera == 0)
{
cout << 0 << endl;
return os;
}
else if (n.numera == n.denom)
{
cout << 1 << endl;
return os
}
else
{
cout << n.numera << '/' << n.denom << endl;
return os;
}
}
friend istream& operator>>(istream &os, Fraction& n)
{
while(!cin.EOF)
{
}
}
}
};
基本上我遇到的问题是遍历文件并获取要分配给作为参数传递的函数的数据成员的字符。
我试图在我的istream成员函数中实现它,但在这种情况下我无法实现它
此外,我的头文件位于上下文中:
#ifndef FRACTION_H
#define FRACTION_H
#include <iostream>
using namespace std;
class Fraction{
public:
Fraction(int , int );
int fraction(int,int);
void reduce_fraction(int *, int *);
Fraction& operator+(const Fraction&);
Fraction& operator-(const Fraction&);
friend ostream& operator<<(ostream &os, const Fraction& n);
friend istream& operator>>(istream &is, const Fraction& n);
};
#endif
答案 0 :(得分:1)
提取运算符>>
应该读取一个分数
使用其他代码读取完整的表达式并计算其值。
它看起来像这样(没有错误检查,只是假设输入的形式正确):
istream& operator >> (istream& is, Fraction& f)
{
char slash = 0;
return is >> f.numerator >> slash >> f.denominator;
}
提示1:您不需要使用单个指针来解决这个问题 - 您只是为自己制造更难的东西。
提示2:您从运营商返回引用,但是分配了添加的结果,例如(1/2 + 3/4) = 7/3
,没有多大意义。
提示3:切勿输入字符&#34; eof&#34;。这并不意味着你的想法。