第十三周项目-项目1-分数类中的运算符重载

/*copyright(c)2016.烟台大学计算机学院
 * All rights reserved,
 * 文件名称:text.Cpp
 * 作者:刘涛
 * 完成日期:2016年5月21日
 * 版本号:vc++6.0
 *问题描述:实现分数类中的运算符重载,在分数类中可以完成分数的加减乘除(运算后再化简)、比较(6种关系)的运算。
 */
#include <iostream>
#include <Cmath>
using namespace std;
class CFraction
{
private:
    int nume;  // 分子
    int deno;  // 分母
public:
    CFraction(int nu=1,int de=1):nume(nu),deno(de) {}
     friend CFraction operator+(const CFraction &c1,const CFraction &c2);//重载加法
     friend CFraction operator-(const CFraction &c1,const CFraction &c2);//重载减法
     friend CFraction operator*(const CFraction &c1,const CFraction &c2);//重载乘法
     friend CFraction operator/(const CFraction &c1,const CFraction &c2);//重载除法

     //二目的比较运算符重载
    bool operator > (const CFraction &c2);
    bool operator < (const CFraction &c2);
    bool operator >= (const CFraction &c2);
    bool operator <= (const CFraction &c2);
    bool operator == (const CFraction &c2);
    bool operator != (const CFraction &c2);

//输入输出的重载
    friend istream &operator>>(istream &in,CFraction &x);
    friend ostream &operator<<(ostream &out,CFraction x);
    void simplify();//分数化简
};
// 重载输入运算符>>
istream &operator>>(istream &in,CFraction &x)
{
    char ch;
    while(1)
    {
        cin>>x.nume>>ch>>x.deno;
        if (x.deno==0)
            cerr<<"分母为0, 请重新输入\n";
        else if(ch!='/')
            cerr<<"格式错误(形如m/n)! 请重新输入\n";
        else
            break;
    }
    return cin;
}

// 重载输出运算符<<
ostream &operator<<(ostream &out,CFraction x)
{
    cout<<x.nume<<'/'<<x.deno;
    return cout;
}
//重载加法
CFraction operator+(const CFraction &c1,const CFraction &c2)
{
    CFraction a;
    a.nume=c1.nume*c2.deno+c2.nume*c1.deno;
    a.deno=c1.deno*c2.deno;
    a.simplify();
    return a;
}
//重载减法
CFraction operator-(const CFraction &c1,const CFraction &c2)
{
    CFraction a;
    a.nume=c1.nume*c2.deno-c2.nume*c1.deno;
    a.deno=c1.deno*c2.deno;
    a.simplify();
    return a;
}
//重载乘法
CFraction operator*(const CFraction &c1,const CFraction &c2)
{
    CFraction a;
    a.nume=c1.nume*c2.nume;
    a.deno=c1.deno*c2.deno;
    a.simplify();
    return a;
}

//重载除法
CFraction operator/(const CFraction &c1,const CFraction &c2)
{
    CFraction a;
    a.nume=c1.nume*c2.deno;
    a.deno=c1.deno*c2.nume;
    a.simplify();
    return a;
}


//二目的比较运算符重载
bool CFraction:: operator > (const CFraction &c2)
{
    int this_nume,c2_nume;
    this_nume=nume*c2.deno;
    c2_nume=c2.nume*deno;
    if(this_nume>c2_nume)
        return true;
    return false;
}


bool CFraction:: operator < (const CFraction &c2)
{
    int this_nume,c2_nume;
    this_nume=nume*c2.deno;
    c2_nume=c2.nume*deno;
    if(this_nume<c2_nume)
        return true;
    return false;
}
bool CFraction::operator==(const CFraction &c2)
{
    if (*this!=c2) return false;
    return true;
}


bool CFraction::operator!=(const CFraction &c2)
{
    if (*this>c2 || *this<c2) return true;
    return false;
}

bool CFraction::operator>=(const CFraction &c2)
{
    if (*this<c2) return false;
    return true;
}

bool CFraction::operator<=(const CFraction &c2)
{
    if (*this>c2) return false;
    return true;
}
void CFraction::simplify()
{
    int de,nu,r;
    de=fabs(deno);
    nu=fabs(nume);
    while(r=nu%de)  // 求m,n的最大公约数
    {
        nu=de;
        de=r;
    }
    deno/=de;     // 化简
    nume/=de;
    if (deno<0)  // 将分母转化为正数
    {
        deno=-deno;
        nume=-nume;
    }
}


int main()
{
    CFraction c1,c2,s;
    cout<<"输入c1: ";
    cin>>c1;
    cout<<"输入c2: ";
    cin>>c2;

    s=c1+c2;
    cout<<"c1+c2="<<s<<endl;;


    s=c1-c2;
    cout<<"c1-c2="<<s<<endl;;


    s=c1*c2;
    cout<<"c1*c2="<<s<<endl;;


    s=c1/c2;
    cout<<"c1/c2="<<s<<endl;;


    if (c1>c2) cout<<"c1>c2"<<endl;
    if (c1<c2) cout<<"c1<c2"<<endl;
    if (c1==c2) cout<<"c1=c2"<<endl;
    if (c1!=c2) cout<<"c1≠c2"<<endl;
    if (c1>=c2) cout<<"c1≥c2"<<endl;
    if (c1<=c2) cout<<"c1<=c2"<<endl;

    return 0;
}
运行结果:
<img src="https://img-blog.csdn.net/20160521140308043?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" />
心得:还没有闹明白为什么<< >> 不可以直接用还得重载。
还有一个疑问就是运算符!=和=重载的时候为什么不能正面否定,而选择否定它的对立面呢,我试过直接否定它但是运行有错误。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
项目:使用 JavaScript 编写的杀死幽灵游戏(附源代码) 杀死鬼魂游戏是使用 Vanilla JavaScript、CSS 和 HTML 画布开发的简单项目。这款游戏很有趣。玩家必须触摸/杀死游荡的鬼魂才能得分。您必须将鼠标悬停在鬼魂上 - 尽量得分。鬼魂在眨眼间不断从一个地方移动到另一个地方。您必须在 1 分钟内尽可能多地杀死鬼魂。 游戏制作 这个游戏项目只是用 HTML 画布、CSS 和 JavaScript 编写的。说到这个游戏的特点,用户必须触摸/杀死游荡的幽灵才能得分。游戏会根据你杀死的幽灵数量来记录你的总分。你必须将鼠标悬停在幽灵上——尽量得分。你必须在 1 分钟内尽可能多地杀死幽灵。游戏还会显示最高排名分数,如果你成功击败它,该分数会在游戏结束屏幕上更新。 该游戏包含大量的 javascript 以确保游戏正常运行。 如何运行该项目? 要运行此游戏,您不需要任何类型的本地服务器,但需要浏览器。我们建议您使用现代浏览器,如 Google Chrome 和 Mozilla Firefox。要玩游戏,首先,单击 index.html 文件在浏览器中打开游戏。 演示: 该项目为国外大神项目,可以作为毕业设计的项目,也可以作为大作业项目,不用担心代码重复,设计重复等,如果需要对项目进行修改,需要具备一定基础知识。 注意:如果装有360等杀毒软件,可能会出现误报的情况,源码本身并无病毒,使用源码时可以关闭360,或者添加信任。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值