第13周项目1 (3)
2016-05-29 21:48
260 查看
/* *copyright(c) 2016,烟台大学计算机与控制工程学院 *All rights reserved *文件名称:test.cpp *作者:李硕 *版本:Code::Blocks * *问题描述:定义分数的一目运算+和-,分别代表分数取正和求反,将“按位取反运算符”~重载为分数的求倒数运算。 *输入描述: *程序输出: */ #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); CFraction operator+();//取正一目运算 CFraction operator-();//取反一目运算 CFraction operator~();//取倒数一目运算 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; } CFraction CFraction::operator+() { return *this; } CFraction CFraction::operator-() { CFraction t; t.nume=-nume; t.deno=deno; return t; } CFraction CFraction::operator~() { CFraction t; t.nume=deno; t.deno=nume; if(t.deno<0)//保证负分数的负号在分子上 { t.deno=-t.deno; t.nume=-t.nume; } 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; }
相关文章推荐
- 算法复习:动态规划算法
- Clojure代码风格
- 牛腩视频总结(一)
- Could not execute JDBC batch update和hibernate.dialect' must be set when no Connection available错误
- JAVA学习总结十一
- Spring execution 表达式
- MySQL查询高速缓冲详解
- java之内部类(InnerClass)----非静态内部类、静态内部类、局部内部类、匿名内部类
- VirtualBox 安装 Centos 7 笔记
- js基本Constructor(构造器)
- 人脸识别(通过照片库区别人物)
- poj 1172 Street Race
- vim、g++、gdb及makefile的学习
- SQL Server 2008新特性——策略管理
- SQListe查询数据练习
- 数据存储——SQLite数据库存储2
- Microsoft.AspNet.SignalR 2.2
- 聚类算法分析
- Linux centos通过安装lszrz用CRT实现与Windows互相传文件
- 二叉树的操作 深度广度遍历,二叉树递归和非递归遍历