第13周项目1 (2)
来源:互联网 发布:睡觉多梦 知乎 编辑:程序博客网 时间:2024/05/03 01:39
/* *copyright(c) 2016,烟台大学计算机与控制工程学院 *All rights reserved *文件名称:test.cpp *作者:李硕 *版本:Code::Blocks * *问题描述: 实现分数类中的对象和整型数的四则运算。分数类中的对象可以和整型数进行四则 运算,且运算符合交换。例如:CFraction a(1,3),b; int i=2;可以完成b=a+i;。 同样,可以完成i+a,45+a,a*27,5/a等各种运算。 *输入描述: *程序输出:*/#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){} void simplify(); void display(); CFraction operator+(const CFraction &c);//两个分数相加,结果要化简 CFraction operator-(const CFraction &c);//两个分数相减,结果要化简 CFraction operator*(const CFraction &c);//两个分数相乘,结果要化简 CFraction operator/(const CFraction &c);//两个分数相除,结果要化简 CFraction operator+(int a); CFraction operator-(int a); CFraction operator*(int a); CFraction operator/(int a); bool operator>(const CFraction &c); bool operator<(const CFraction &c); bool operator==(const CFraction &c); bool operator!=(const CFraction &c); bool operator>=(const CFraction &c); bool operator<=(const CFraction &c);};void CFraction::display(){ cout<<nume<<"/"<<deno<<endl;}//分数简化void CFraction::simplify(){ int m,n,t; n=fabs(deno); m=fabs(nume); while(t=m%n)// 求m,n的最大公约数 { m=n; n=t; } deno/=n; nume/=n; if(deno<0) { deno=-deno; nume=-nume; }}CFraction CFraction::operator+(const CFraction &c){ CFraction t; t.nume=nume*c.deno+c.nume*deno; t.deno=deno*c.deno; t.simplify(); return t;}CFraction CFraction::operator-(const CFraction &c){ CFraction t; t.nume=nume*c.deno-c.nume*deno; t.deno=deno*c.deno; t.simplify(); return t;}CFraction CFraction::operator*(const CFraction &c){ CFraction t; t.nume=nume*c.nume; t.deno=deno*c.deno; t.simplify(); return t;}CFraction CFraction::operator/(const CFraction &c){ CFraction t; t.nume=nume*c.deno; t.deno=deno*c.nume; t.simplify(); return t;}CFraction CFraction::operator+(int a){ CFraction t; int c; c=a*deno; t.deno=deno; t.nume=nume+c; t.simplify(); return t;}CFraction CFraction::operator-(int a){ CFraction t; int c; c=a*deno; t.deno=deno; t.nume=nume-c; t.simplify(); return t;}CFraction CFraction::operator*(int a){ CFraction t; t.deno=deno; t.nume=nume*a; t.simplify(); return t;}CFraction CFraction::operator/(int a){ CFraction t; t.deno=deno*a; t.nume=nume; t.simplify(); return t;}bool CFraction::operator>(const CFraction &c){ int n1,d1; n1=nume*c.deno-c.nume*deno; d1=deno*c.deno; if(n1*d1>0) return true; return false;}bool CFraction::operator<(const CFraction &c){ int n1,d1; n1=nume*c.deno-c.nume*deno; d1=deno*c.deno; if(n1*d1<0) return true; return false;}bool CFraction::operator==(const CFraction &c){ if(*this!=c) return false; return true;}bool CFraction::operator!=(const CFraction &c){ if(*this==c) return false; return true;} bool CFraction::operator>=(const CFraction &c){ if(*this<c) return false; return true;} bool CFraction::operator<=(const CFraction &c){ if(*this>c) return false; return true;}int main(){ char c; int n,d; cout<<"输入分数的样例:x/y"<<endl; cin>>n>>c>>d; CFraction x(n,d); x.display(); cin>>n>>c>>d; CFraction y(n,d); y.display(); CFraction s; s=x+y; cout<<"x+y="; s.display(); cout<<endl; s=x-y; cout<<"x-y="; s.display(); cout<<endl; s=x*y; cout<<"x*y="; s.display(); cout<<endl; s=x/y; cout<<"x/y="; s.display(); cout<<endl; cout<<"请输入要进行运算的整数d"<<endl; cin>>d; s=x+d; cout<<"x+d="; s.display(); cout<<endl; s=x-d; cout<<"x-d="; s.display(); cout<<endl; s=x*d; cout<<"x*d="; s.display(); cout<<endl; s=x/d; cout<<"x/d="; s.display(); cout<<endl; if(x>y) cout<<"大于!"<<endl; if(x<y) cout<<"小于! "<<endl; if(x==y) cout<<"等于!"<<endl; return 0;}
0 0
- 第13周项目1(2)
- 第13周项目1-(2)
- 第13周项目1 (2)
- 第13周项目2 (1)
- 第13周项目1-2
- 第13周项目2 (2)
- 第13周项目1-(1)
- 第13周项目1 (1)
- 第13周项目1(1)
- 第13周 【项目 - 链表类】(2)
- 第13周项目2 (3)
- 第13周 项目二(2)
- 第13周项目1(3)
- 第13周项目1(4)
- 第13周项目1-(3)
- 第13周项目1(5)
- 第13周项目1(4)
- 第13周项目1-(5)
- 【Leetcode】Word Break
- JavaScript框架思想3
- 无痛安装MS出品的android虚拟机
- Exam 2 Maximum Xor with Prefix and Suffix - Works Application 16
- 菜鸟的安卓之路。2016.05.29
- 第13周项目1 (2)
- 偶遇processing
- 二叉树的深度优先遍历和广度优先遍历
- Could not execute JDBC batch update和hibernate.dialect' must be set when no Connection available错误
- 二维费用的背包问题
- 图像灰度化的实现
- 【Leetcode】Coin Change
- 【Leetcode】Count of Smaller Numbers After Self
- 二叉树的操作 深度广度遍历,二叉树递归和非递归遍历