利用运算符重载进行有理数的计算

定义一个有理数类。一个有理数类是一个可以表示成两个整数相除的数,如1/2、2/3、4/5。一个有理数类有两个整数成员表示:分子和分母。要求能检测分母为0问题,能化简,重载+、-、*、/运算符完成四则运算,重载“==”符号判断两个有理数是否相等。

#include <iostream>
using namespace std;
class Youli
{
public:
    Youli(double r=0.0,double i=0.0);
    friend Youli operator +(Youli a,Youli b);//重载二元加
    friend Youli operator -(Youli a,Youli b);//重载二元减
    friend Youli operator *(Youli a,Youli b);
    friend Youli operator /(Youli a,Youli b);
    friend Youli operator==(Youli a,Youli b);
    void display();
    void huajian();
private:
    double zi,mu;
};
Youli ::Youli(double r,double i)
{
   zi=r;mu=i;
   
}
Youli operator +(Youli a,Youli b)
{
    int x;
    int y;
    if(a.mu==0||b.mu==0)
    {
        cout<<"分母不可以为0"<<endl;
    
    }
    else
    {
        x=a.zi*b.mu+b.zi*a.mu;
    y=a.mu*b.mu;
    Youli temp(x,y);
    temp.huajian();
    //return temp;
    //cout<<"jsdho"<<endl;
    temp.display();
    }
   
}
Youli operator -(Youli a,Youli b)
{
    if(a.mu==0||b.mu==0)
    {
        cout<<"分母不可以为0"<<endl;
    }
    else
    {
        int x;
    int y;
    x=a.zi*b.mu-b.zi*a.mu;
    y=a.mu*b.mu;
    Youli m(x,y);
    m.huajian();
    //return m;
    //cout<<"jdiaj0"<<endl;
    m.display();
    }
    
}
Youli operator *(Youli a,Youli b)
{
    if(a.mu==0||b.mu==0)
    {
        cout<<"分母不可以为0"<<endl;
    }
    else
    {
            int x;
    int y;
    x=a.zi*b.zi;
    y=a.mu*b.mu;
    Youli t(x,y);
    t.huajian();
    //return t;
    t.display();
    }

}
Youli operator /(Youli a,Youli b)
{
    if(a.mu==0||b.mu==0)
    {
        cout<<"分母不可以为0"<<endl;
    }
    else
    {
        int x;
    int y;
    x=a.zi*b.mu;
    y=a.mu*b.zi;
    Youli di(x,y);
    di.huajian();
    //return di;
    di.display();
    }
    
}
Youli operator==(Youli a,Youli b)
{
    if(a.mu==0||b.mu==0)
    {
        cout<<"分母不可以为0"<<endl;
    }
    else
    {
    if(a.mu*b.zi&&a.mu==b.zi)
    {
        cout<<"EQUAL"<<endl;
        
     }
     else {
         cout<<"UNEQUAL"<<endl;
     }
     }
}
void Youli::huajian()
{
    int m,n,i;
    n=this->mu;
    m=this->zi;
    if(this->mu==this->zi)
    {
    n=1;
    m=1;
    }
    if(m>n)
    {
    i=n;
    }
for(i=m;i>=1;i--)
    {
        if((m%i==0)&&(n%i==0))
        {
            //cout<<i<<" ";
            m=m/i;
            n=n/i;
        }
    }
    if(m<0)
    {
        m=-m;
        if(m>n)
    {
    i=n;
    }
for(i=m;i>=1;i--)
    {
        if((m%i==0)&&(n%i==0))
        {
            //cout<<i<<" ";
            m=m/i;
            n=n/i;
        }
    }
    m=-m;
    }
        this->zi=m;
        this->mu=n;
    
}
void Youli::display()
{
        if(zi==1&&mu==1){
                cout<<1<<endl;
            }
            else if(zi==0)
            {
                cout<<0;
            }
            else
            {
                cout<<zi<<"/"<<mu<<endl;
            }
}
int main()
{
    Youli a(1,8);
    Youli b(1,2);
    Youli c;
    Youli d;
    Youli e;
    Youli f;
    f=a/b;
    f=a==b;
    e=a*b;
    d=a-b;
    c=a+b;
    
}

  • 1
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值