如何修复分数 class 的重载 + 运算符的输出?
How do I fix the output of my fraction class's overloaded + operator?
我对我的 fractionType class 有疑问。我正在为赋值编码,赋值要求我重载基本算术运算符(+、-、/、*)、逻辑运算符(==、<、>、=<、=>)和系统运算符(<< , >>)
到目前为止,我有系统运算符在工作,以及乘法和除法运算符。当我测试 + 和 - 运算符时,我的问题出现了。
我的输入被硬编码为 2/4 和 1/8,但我的输出是 3/8。这是不对的。
我的代码来自 fractionType.cpp
#include <iostream>
#include "fractionType.h"
fractionType::fractionType(){
}
fractionType::fractionType(int a, int b) {
numerator = a;
denominator = b;
}
fractionType fractionType::operator+(fractionType fraction) {
fractionType anotherFraction;
if (denominator = fraction.denominator) {
anotherFraction.numerator = numerator + fraction.numerator;
anotherFraction.denominator = denominator;
}
if (denominator != fraction.denominator) {
anotherFraction.numerator = ((numerator) * (fraction.denominator)) + ((fraction.numerator) * (denominator));
anotherFraction.denominator = denominator * fraction.denominator;
}
return anotherFraction;
}
fractionType fractionType::operator-(fractionType fraction) {
fractionType anotherFraction;
if (denominator = fraction.denominator) {
anotherFraction.numerator = numerator - fraction.numerator;
anotherFraction.denominator = denominator;
}
else {
anotherFraction.numerator = (numerator * fraction.denominator) - (fraction.numerator * fraction.denominator);
anotherFraction.denominator = denominator * fraction.denominator;
}
return anotherFraction;
}
我的代码来自 fractionType.h
#include <iostream>
class fractionType {
public:
fractionType(int a, int b);
fractionType();
fractionType operator*(fractionType fraction);
fractionType operator/(fractionType fraction);
fractionType operator+(fractionType fraction);
fractionType operator-(fractionType fraction);
friend std::ostream& operator<<(std::ostream& out, const fractionType &fraction) {
out << fraction.numerator << '/' << fraction.denominator;
return out;
}
friend std::istream& operator>> (std::istream& in, fractionType &fraction) {
char c;
in >> fraction.numerator >> c >> fraction.denominator;
return in;
}
private:
int numerator, denominator;
};
#endif FRACTIONTYPE_H
和我的 source.cpp
#include <iostream>
#include "fractionType.h"
int main() {
fractionType aFraction(2, 4);
fractionType bFraction(1, 8);
fractionType cFraction;
cFraction = aFraction + bFraction;
std::cout << cFraction << std::endl;
system("PAUSE");
}
我删除了我的 operator* 和 operator/,因为它们可以正常工作。
我不知道我做错了什么,在我发布这个问题之前我已经一遍又一遍地复习数学。是因为我没有使用指针吗?常量?或者它有什么不同?在此先感谢您的帮助!
这一行是错误的:
if (denominator = fraction.denominator) {
必须是
if (denominator == fraction.denominator) {
如果启用警告,clang 和 gcc 会告诉您,例如:
main.cpp:32:19: warning: using the result of an assignment as a condition without parentheses [-Wparentheses]
if (denominator = fraction.denominator) {
~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~
如果您更正上述错误,您的代码将有效:
输出
20/32
我对我的 fractionType class 有疑问。我正在为赋值编码,赋值要求我重载基本算术运算符(+、-、/、*)、逻辑运算符(==、<、>、=<、=>)和系统运算符(<< , >>) 到目前为止,我有系统运算符在工作,以及乘法和除法运算符。当我测试 + 和 - 运算符时,我的问题出现了。 我的输入被硬编码为 2/4 和 1/8,但我的输出是 3/8。这是不对的。
我的代码来自 fractionType.cpp
#include <iostream>
#include "fractionType.h"
fractionType::fractionType(){
}
fractionType::fractionType(int a, int b) {
numerator = a;
denominator = b;
}
fractionType fractionType::operator+(fractionType fraction) {
fractionType anotherFraction;
if (denominator = fraction.denominator) {
anotherFraction.numerator = numerator + fraction.numerator;
anotherFraction.denominator = denominator;
}
if (denominator != fraction.denominator) {
anotherFraction.numerator = ((numerator) * (fraction.denominator)) + ((fraction.numerator) * (denominator));
anotherFraction.denominator = denominator * fraction.denominator;
}
return anotherFraction;
}
fractionType fractionType::operator-(fractionType fraction) {
fractionType anotherFraction;
if (denominator = fraction.denominator) {
anotherFraction.numerator = numerator - fraction.numerator;
anotherFraction.denominator = denominator;
}
else {
anotherFraction.numerator = (numerator * fraction.denominator) - (fraction.numerator * fraction.denominator);
anotherFraction.denominator = denominator * fraction.denominator;
}
return anotherFraction;
}
我的代码来自 fractionType.h
#include <iostream>
class fractionType {
public:
fractionType(int a, int b);
fractionType();
fractionType operator*(fractionType fraction);
fractionType operator/(fractionType fraction);
fractionType operator+(fractionType fraction);
fractionType operator-(fractionType fraction);
friend std::ostream& operator<<(std::ostream& out, const fractionType &fraction) {
out << fraction.numerator << '/' << fraction.denominator;
return out;
}
friend std::istream& operator>> (std::istream& in, fractionType &fraction) {
char c;
in >> fraction.numerator >> c >> fraction.denominator;
return in;
}
private:
int numerator, denominator;
};
#endif FRACTIONTYPE_H
和我的 source.cpp
#include <iostream>
#include "fractionType.h"
int main() {
fractionType aFraction(2, 4);
fractionType bFraction(1, 8);
fractionType cFraction;
cFraction = aFraction + bFraction;
std::cout << cFraction << std::endl;
system("PAUSE");
}
我删除了我的 operator* 和 operator/,因为它们可以正常工作。 我不知道我做错了什么,在我发布这个问题之前我已经一遍又一遍地复习数学。是因为我没有使用指针吗?常量?或者它有什么不同?在此先感谢您的帮助!
这一行是错误的:
if (denominator = fraction.denominator) {
必须是
if (denominator == fraction.denominator) {
如果启用警告,clang 和 gcc 会告诉您,例如:
main.cpp:32:19: warning: using the result of an assignment as a condition without parentheses [-Wparentheses]
if (denominator = fraction.denominator) {
~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~
如果您更正上述错误,您的代码将有效:
输出
20/32