C++重載運算符實現(xiàn)分?jǐn)?shù)加減乘除
更新時間:2021年06月28日 09:32:52 作者:Quellaaa
這篇文章主要為大家詳細(xì)介紹了C++重載運算符實現(xiàn)分?jǐn)?shù)加減乘除,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了C++重載運算符實現(xiàn)分?jǐn)?shù)加減乘除的具體代碼,供大家參考,具體內(nèi)容如下
實現(xiàn)結(jié)果如下圖所示:

代碼如下所示:
#include <iostream>
using namespace std;
class Rational {
public:
Rational operator+(Rational rhs);
Rational operator-(Rational rhs);
Rational operator*(Rational rhs);
Rational operator/(Rational rhs);
Rational(int num, int denom);
private:
void normalize(); //負(fù)責(zé)對分?jǐn)?shù)做化簡工作
int numerator;//分子
int denominator;//分母
friend std::ostream& operator<<(ostream& os, Rational f);
};
Rational::Rational(int num, int denom) {
numerator = num;
denominator = denom;
normalize();
}
//只允許分子為負(fù)數(shù),若分母為負(fù)數(shù)則把負(fù)數(shù)挪到分子部分
//利用歐幾里得算法將分?jǐn)?shù)簡化
void Rational::normalize() {
if (denominator < 0) {
numerator = -numerator;
denominator = -denominator;
}
//歐幾里得算法
int a = abs(numerator);
int b = abs(denominator);
//求出最大公約數(shù),a
//eg: a=12,b=9.
//t=3 a=9 b=3
//t=0 a=3 b=0
while (b > 0) {
int t = a % b;//t為余數(shù)
a = b; //a取除數(shù)
b = t; //b取余數(shù)
}
//分子、分母分別處以最大公約數(shù)
numerator /= a;
denominator /= a;
}
//重載運算符函數(shù)是類的成員函數(shù)
//分?jǐn)?shù)是先通分再加減
// a*d+b*c / b*d
Rational Rational::operator+(Rational rhs) {
int a = numerator;
int b = denominator;
int c = rhs.numerator;
int d = rhs.denominator;
return Rational(a*d+b*c,b*d);
}
Rational Rational::operator-(Rational rhs) {
int a = numerator;
int b = denominator;
int c = rhs.numerator;
int d = rhs.denominator;
return Rational(a*d - b*c, b*d);
/*
**這里有個偷懶的寫法
rhs.numerator = -rhs.numerator;
return operator+(rhs);
*/
}
Rational Rational::operator*(Rational rhs) {
int a = numerator;
int b = denominator;
int c = rhs.numerator;
int d = rhs.denominator;
return Rational(a*c, b*d);
}
Rational Rational::operator/(Rational rhs) {
int t = rhs.denominator;
rhs.denominator = rhs.numerator;
rhs.numerator = t;
return operator*(rhs);
}
//該函數(shù)是友元函數(shù),因此不用加空間域名
ostream& operator<<(ostream& os, Rational f);
int main() {
Rational r1(4, 18);
Rational r2(14, 18);
cout << r1 << " + " << r2 << " = " << (r1 + r2) << endl;
cout << r1 << " - " << r2 << " = " << (r1 - r2) << endl;
cout << r1 << " * " << r2 << " = " << (r1 * r2) << endl;
cout << r1 << " / " << r2 << " = " << (r1 / r2) << endl;
system("pause");
return 0;
}
ostream& operator<<(ostream& os, Rational f) {
os << f.numerator << "/" << f.denominator;
return os;
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C語言實現(xiàn)將double/float 轉(zhuǎn)為字符串(帶自定義精度)
這篇文章主要介紹了C語言實現(xiàn)將double/float 轉(zhuǎn)為字符串(帶自定義精度),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12
數(shù)據(jù)結(jié)構(gòu)與算法中二叉樹子結(jié)構(gòu)的詳解
這篇文章主要介紹了數(shù)據(jù)結(jié)構(gòu)與算法中二叉樹子結(jié)構(gòu)的詳解的相關(guān)資料,需要的朋友可以參考下2017-04-04
C++11 線程同步接口std::condition_variable和std::future的簡單使用示例詳
本文介紹了std::condition_variable和std::future在C++中的應(yīng)用,用于線程間的同步和異步執(zhí)行,通過示例代碼,展示了如何使用std::condition_variable的wait和notify接口進(jìn)行線程間同步2024-09-09

