/*
* Copyright (c) 2014, 烟台大学计算机学院
* All rights reserved.
* 作 者:沈远宏
* 完成日期:2014 年 4 月 18 日
* 版 本 号:v1.0
* 输入描述: 无
* 问题描述:实现分数类中的运算符重载,在分数类中可以完成分数的加减乘除(运算后再化简)、比较(6种关系)的运算。
可以以第5周项目2的代码为基础开始工作.分数类中的对象可以和整型数进行四则运算,且运算符合交换律。例
如:CFractiona(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 set(int nu,int de);//赋值
void simplify(); //化简
void output();
friend CFraction operator+(CFraction &a,int &b);// +
friend CFraction operator+(int &b,CFraction &a);
friend CFraction operator-(CFraction &a,int &b);// -
friend CFraction operator-(int &b,CFraction &a);
friend CFraction operator*(CFraction &a,int &b);// *
friend CFraction operator*(int &b,CFraction &a);
friend CFraction operator/(CFraction &a,int &b);// /
friend CFraction operator/(int &b,CFraction &a);
//构造函数及运算符重载的函数声明
};
void CFraction::set(int nu,int de)//赋值
{
nume=nu;
deno=de;
}
void CFraction::simplify() //化简
{
int t,r,x=nume,y=deno; //求分子分母的最大公约数
if(x<y)t=x,x=y,x=t;
while(y!=0)
{
r=x%y;
x=y;
y=r;
}
nume=(CFraction::nume/x);
deno=(CFraction::deno/x);
}
void CFraction::output()
{
cout<<nume<<"/"<<deno<<endl;
}
CFraction operator+(CFraction &a,int &b)// +
{
CFraction c;
c.nume=a.nume+b*a.deno;
c.deno=a.deno;
c.simplify();
return c;
}
CFraction operator+(int &b,CFraction &a)// +
{
CFraction c;
c.nume=a.nume+b*a.deno;
c.deno=a.deno;
c.simplify();
return c;
}
CFraction operator-(CFraction &a,int &b)// -
{
CFraction c;
c.nume=a.nume-b*a.deno;
c.deno=a.deno;
c.simplify();
return c;
}
CFraction operator-(int &b,CFraction &a)// -
{
CFraction c;
c.nume=b*a.deno-a.nume;
c.deno=a.deno;
c.simplify();
return c;
}
CFraction operator*(CFraction &a,int &b)// *
{
CFraction c;
c.nume=a.nume*b;
c.deno=a.deno;
c.simplify();
return c;
}
CFraction operator*(int &b,CFraction &a)// *
{
CFraction c;
c.nume=a.nume*b;
c.deno=a.deno;
c.simplify();
return c;
}
CFraction operator/(CFraction &a,int &b)// /
{
CFraction c;
c.nume=a.nume;
c.deno=a.deno*b;
c.simplify();
return c;
}
CFraction operator/(int &b,CFraction &a)// /
{
CFraction c;
c.nume=b*a.deno;
c.deno=a.nume;
c.simplify();
return c;
}
//重载函数的实现及用于测试的main()函数
int main()
{
CFraction x(1,3),s;
int i=5;
cout<<"分数x=1/3 i=5"<<endl;
s=x+i;
cout<<"x+i=";
s.output();
s=x-i;
cout<<"x-i=";
s.output();
s=i*x;
cout<<"i*x=";
s.output();
s=i/x;
cout<<"i/x=";
s.output();
cout<<endl;
return 0;
}
运行结果:
心得体会:
曾经尝试过把类模板和operator放在一起,结果总是报错,问了张玉老师,老师说这事要问老贺,老贺爱研究这些。哈哈
最近很喜欢一个手机APP叫2048,很简单但是玩着不容易,玩的时候我就一直在想什么时候我也能编出这么令人着迷的程序啊,我的心愿是做游戏开发啊,本来自己也挺喜欢玩游戏,不过不知道什么时候才能做到,现在觉得俄罗斯方块都做不出来,尝试一下问度娘吧。