第7周项目4-分数类中的运算符重载(2)

本文记录了在C++中实现分数类的运算符重载过程,通过友元函数进行操作。作者分享了一段较长的代码实现,并提到因一个字母错误导致的全部修改经历。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/*
*copyright (c)2015,烟台大学计算机学院
*All rights reserved
*文件名称:project.cpp
*作者:孙春红
*完成日期:2015年4月30日
*版本号:v1.0
*
*问题描述:在(1)的基础上,实现分数类中的对象和整型数的四则运算。
分数类中的对象可以和整型数进行四则运算,且运算符合交换律。例如
CFraction a(1,3),b; int i=2; 可以完成b=a+i;。同样,可以完成i+a,
 45+a, a*27, 5/a等各种运算。
*输入描述:略。
*程序输出:略。
*/
#include<iostream>
using namespace std;
class CFraction
{
private:
    int nume;  // 分子
    int deno;  // 分母
public:
    //构造函数及运算符重载的函数声明
    CFraction(int nu=0,int de=1):nume(nu),deno(de) {}
    void simplify();
    void display ();
    friend bool operator > (CFraction &c1,CFraction &c2);
    friend bool operator < (CFraction &c1,CFraction &c2);
    friend bool operator >=(CFraction &c1,CFraction &c2);
    friend bool operator <=(CFraction &c1,CFraction &c2);
    friend bool operator ==(CFraction &c1,CFraction &c2);
    friend bool operator !=(CFraction &c1,CFraction &c2);
    friend CFraction operator +(CFraction &c1,CFraction &c2);
    friend CFraction operator -(CFraction &c1,CFraction &c2);
    friend CFraction operator *(CFraction &c1,CFraction &c2);
    friend CFraction operator /(CFraction &c1,CFraction &c2);
    friend CFraction operator +(int d,CFraction &c);
    friend CFraction operator -(int d,CFraction &c);
    friend CFraction operator *(int d,CFraction &c);
    friend CFraction operator /(int d,CFraction &c);
    friend CFraction operator +(CFraction &c,int d);
    friend CFraction operator -(CFraction &c,int d);
    friend CFraction operator *(CFraction &c,int d);
    friend CFraction operator /(CFraction &c,int d);
    friend bool operator>( CFraction &c, int i);
    friend bool operator>(int i,CFraction &c);
    friend bool operator<( CFraction &c, int i);
    friend bool operator<(int i,CFraction &c);
    friend bool operator==( CFraction &c, int i);
    friend bool operator==(int i,CFraction &c);
    friend bool operator!=(CFraction &c, int i);
    friend bool operator!=(int i,CFraction &c);
    friend bool operator>=(CFraction &c, int i);
    friend bool operator>=(int i,CFraction &c);
    friend bool operator<=(CFraction &c, int i);
    friend bool operator<=(int i,CFraction &c);
};
//重载函数的实现
void CFraction::simplify()
{
    int r,m,n;
    m=deno;
    n=nume;
    while(r=m%n)  // 求m,n的最大公约数
    {
        m=n;
        n=r;
    }
    deno/=n;
    nume/=n;
}
void CFraction::display()
{
    cout<<"("<<nume<<"/"<<deno<<")"<<endl;
}
bool operator > (CFraction &c1,CFraction &c2)
{
    if ((c1.nume*c2.deno)>(c2.nume*c1.deno))
        return true;
    return false;
}
bool operator < (CFraction &c1,CFraction &c2)
{
    if ((c1.nume*c2.deno)<(c2.nume*c1.deno))
        return true;
    return false;
}
bool operator >=(CFraction &c1,CFraction &c2)
{
    if (c1<c2)
        return false;
    return true;
}
bool operator <=(CFraction &c1,CFraction &c2)
{
    if (c1>c2)
        return false;
    return true;
}
bool operator ==(CFraction &c1,CFraction &c2)
{
    if ((c1<c2)||(c1>c2))
        return false;
    return true;
}
bool operator !=(CFraction &c1,CFraction &c2)
{
    if (c1==c2)
        return false;
    return true;
}
bool operator>(CFraction &c, int i)
{
    if(c.deno>0)
        return c.nume>(i*c.deno); //继续去判断“>”两边数的大小
    else
        return c.nume<(i*c.deno);
}
bool operator>(int i,CFraction &c)
{
    if(c.deno>0)
        return (i*c.deno)>c.nume;
    else
        return (i*c.deno)<c.nume;
}

bool operator<( CFraction &c, int i)
{
    if(c.deno>0)
        return c.nume<(i*c.deno);
    else
        return c.nume>(i*c.deno);
}
bool operator<(int i,CFraction &c)
{
    if(c.deno>0)
        return (i*c.deno)<c.nume;
    else
        return (i*c.deno)>c.nume;
}

bool operator==(CFraction &c, int i)
{
    return c.nume==(i*c.deno);
}
bool operator==(int i, CFraction &c)
{
    return c.nume==(i*c.deno);
}
bool operator!=( CFraction &c, int i)
{
    return c.nume!=(i*c.deno);
}
bool operator!=(int i, CFraction &c)
{
    return c.nume!=(i*c.deno);
}
bool operator>=( CFraction &c, int i)
{
    return !(c<i);
}
bool operator>=(int i, CFraction &c)
{
    return !(i<c);
}

bool operator<=( CFraction &c, int i)
{
    return !(c>i);
}
bool operator<=(int i,CFraction &c)
{
    return !(i>c);
}
CFraction operator +(CFraction &c1,CFraction &c2)
{
    CFraction c;
    c.deno=c1.deno*c2.deno;
    c.nume=c1.nume*c2.deno+c2.nume*c1.deno;
    c.simplify();
    return c;
}
CFraction operator -(CFraction &c1,CFraction &c2)
{
    CFraction c;
    c.deno=c1.deno*c2.deno;
    c.nume=c1.nume*c2.deno-c2.nume*c1.deno;
    c.simplify();
    return c;
}
CFraction operator *(CFraction &c1,CFraction &c2)
{
    CFraction c;
    c.deno=c1.deno*c2.deno;
    c.nume=c1.nume*c2.nume;
    c.simplify();
    return c;
}
CFraction operator /(CFraction &c1,CFraction &c2)
{
    CFraction c;
    c.deno=c1.deno*c2.nume;
    c.nume=c1.nume*c2.deno;
    c.simplify();
    return c;
}
CFraction operator +(int d,CFraction &c)
{
    CFraction c1;
    c1.deno=c.deno;
    c1.nume=c.nume+d*c.deno;
    c1.simplify();
    return c1;
}
CFraction operator +(CFraction &c,int d)
{
    CFraction c1;
    c1.deno=c.deno;
    c1.nume=c.nume+d*c.deno;
    c1.simplify();
    return c1;
}
CFraction operator -(int d,CFraction &c)
{
    CFraction c1;
    c1.deno=c.deno;
    c1.nume=d*c.deno-c.nume;
    c1.simplify();
    return c1;
}
CFraction operator -(CFraction &c,int d)
{
    CFraction c1;
    c1.deno=c.deno;
    c1.nume=c.nume-d*c.deno;
    c1.simplify();
    return c1;
}
CFraction operator *(int d,CFraction &c)
{
    CFraction c1;
    c1.deno=c.deno;
    c1.nume=d*c.nume;
    c1.simplify();
    return c1;
}
CFraction operator *(CFraction &c,int d)
{
    CFraction c1;
    c1.deno=c.deno;
    c1.nume=d*c.nume;
    c1.simplify();
    return c1;
}
CFraction operator /(CFraction &c,int d)
{
    CFraction c1;
    c1.deno=c.deno*d;
    c1.nume=c.nume;
    c1.simplify();
    return c1;
}
CFraction operator /(int d,CFraction &c)
{
    CFraction c1;
    c1.deno=c.nume;
    c1.nume=d*c.deno;
    c1.simplify();
    return c1;
}
int main()
{
    CFraction x(1,3),y(-5,10),s;
    cout<<"分数x=1/3      y=-5/10"<<endl;
    s=x+y;
    cout<<"x+y=";
    s.display();
    s=x-y;
    cout<<"x-y=";
    s.display();
    s=x*y;
    cout<<"x*y=";
    s.display();
    s=x/y;
    cout<<"x/y=";
    s.display();
    x.display();
    if (x>y) cout<<"大于"<<endl;
    if (x<y) cout<<"小于"<<endl;
    if (x==y) cout<<"等于"<<endl;
     y.display();
    cout<<endl;
    s=x-1;
    cout<<"x-1=";
    s.display();
    if (x>s) cout<<"大于"<<endl;
    if (x<s) cout<<"小于"<<endl;
    if (x==s) cout<<"等于"<<endl;
    return 0;
}


运行结果:

知识点总结:

运用友元函数实现分数类中的运算符重载。

学习心得:

好长的代码。。。因为定义的时候错了一个小字母,结果,从头改到位。。。。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值