分數的四則運算(c++重載練習)
來源:互聯網
上載者:User
/**分數的四則運算*重載運算子的實現*最簡分數列印結果 **/#include<iostream>usingnamespacestd;classfenShu//分數類{public:intfenZi;//分子intfenMu;//分母fenShuinput(intfz,intfm);//輸入函數voidoutput();//輸出函數fenShuoperator+(fenShu&);//重載四則運算fenShuoperator-(fenShu&);fenShuoperator*(fenShu&);fenShuoperator/(fenShu&);};fenShufenShu::operator+(fenShu&a)//加號重載{fenShug;g.fenMu=fenMu*a.fenMu;g.fenZi=fenZi*a.fenMu+a.fenZi*fenMu;returng;}fenShufenShu::operator-(fenShu&a)//減號重載{fenShug;g.fenMu=fenMu*a.fenMu;g.fenZi=fenZi*a.fenMu-a.fenZi*fenMu;returng;}fenShufenShu::operator*(fenShu&a)//乘號重載{fenShug;g.fenMu=fenMu*a.fenMu;g.fenZi=fenZi*a.fenZi;returng;}fenShufenShu::operator/(fenShu&a)//除號重載{fenShug;g.fenMu=fenMu*a.fenZi;g.fenZi=fenZi*a.fenMu;returng;}fenShufenShu::input(intfz,intfm)//輸入實現{fenShua;a.fenZi=fz;a.fenMu=fm;returna;}voidfenShu::output()//最簡分數輸出{for(inti=2;i<=fenZi||i<=fenMu;i++){if(fenZi%i==0&&fenMu%i==0)//找出分子分母最大公約數i{fenZi=fenZi/i;//簡化分子fenMu=fenMu/i;//簡化分母}}cout<<fenZi<<"/"<<fenMu<<endl;//列印簡化後的分數}voidmain(){fenShus1,s2,s3;intfenzi1,fenmu1,fenzi2,fenmu2;cout<<"請輸入第一個分數的分子(空格)分母"<<endl;cin>>fenzi1;cin>>fenmu1;cout<<"請輸入第二個分數的分子(空格)分母"<<endl;cin>>fenzi2;cin>>fenmu2;s1=s1.input(fenzi1,fenmu1);s2=s2.input(fenzi2,fenmu2);//列印分數加+法格式以及運算後的結果s3=s1+s2;cout<<fenzi1<<"/"<<fenmu1<<"+"<<fenzi2<<"/"<<fenmu2<<"=";s3.output();//列印分數減-法格式以及運算後的結果s3=s1-s2;cout<<fenzi1<<"/"<<fenmu1<<"-"<<fenzi2<<"/"<<fenmu2<<"=";s3.output();//列印分數乘*法格式以及運算後的結果s3=s1*s2;cout<<fenzi1<<"/"<<fenmu1<<"*"<<fenzi2<<"/"<<fenmu2<<"=";s3.output();//列印分數除/法格式以及運算後的結果s3=s1/s2;cout<<fenzi1<<"/"<<fenmu1<<"/"<<fenzi2<<"/"<<fenmu2<<"=";s3.output();}