分数的四则运算(c++重载练习)

/*
* 分数的四则运算
* 重载运算符的实现
* 最简分数打印结果
 **/

#include
using namespace std;

class fenShu                       //分数类
{
	
public:	
	int fenZi;                      //分子
	int fenMu;                      //分母
	fenShu input(int fz ,int fm);   //输入函数
    void output();                  //输出函数
	fenShu operator +(fenShu &);    //重载四则运算
	fenShu operator -(fenShu &);
	fenShu operator *(fenShu &);
	fenShu operator /(fenShu &);	
	
};

fenShu fenShu::operator+(fenShu &a)  //加号重载
{
	fenShu g;
	g.fenMu=fenMu*a.fenMu;
	g.fenZi=fenZi*a.fenMu+a.fenZi*fenMu;
	return g;
}
fenShu fenShu::operator-(fenShu &a)  //减号重载
{
	fenShu g;
	g.fenMu=fenMu*a.fenMu;
	g.fenZi=fenZi*a.fenMu-a.fenZi*fenMu;
	return g;
}
fenShu fenShu::operator*(fenShu &a)  //乘号重载
{
	fenShu g;
	g.fenMu=fenMu*a.fenMu;
	g.fenZi=fenZi*a.fenZi;
	return g;
}
fenShu fenShu::operator/(fenShu &a)  //除号重载
{
	fenShu g;
	g.fenMu=fenMu*a.fenZi;
	g.fenZi=fenZi*a.fenMu;
	return g;
}
fenShu fenShu::input(int fz ,int fm)  //输入实现
{ 
	fenShu a;
	a.fenZi=fz;a.fenMu=fm;
	return a;
}
void fenShu::output()               //最简分数输出
{	
	for(int i=2;i<=fenZi||i<=fenMu;i++)
	{
		if(fenZi%i==0&&fenMu%i==0)   //找出分子分母最大公约数i
		{
			fenZi=fenZi/i;           //简化分子
			fenMu=fenMu/i;           //简化分母
		}
		
	}
	cout<>fenzi1;
        cin>>fenmu1;
	
	cout<<"请输入第二个分数的分子(空格)分母"<>fenzi2;
	cin>>fenmu2;
	
	s1=s1.input(fenzi1,fenmu1);
	
	s2=s2.input(fenzi2,fenmu2);
	
	//打印分数加+法格式以及运算后的结果
	s3=s1+s2;
	cout<

你可能感兴趣的:(C++)