定义一个分数类,分子分母各为私有成员,

简介: /*定义一个分数类,分子分母各为私有成员, 规则:默认构造函数分数为1 分子分母要以最简形式存放。如3/9=1/3 定义成员Add,Sub,Mul和Div计算结果仍以最简形式存放 以浮点形式打印分数 思路:问题1.如何对分数约分。
/*定义一个分数类,分子分母各为私有成员,
规则:默认构造函数分数为1
      分子分母要以最简形式存放。如3/9=1/3
	  定义成员Add,Sub,Mul和Div计算结果仍以最简形式存放
	  以浮点形式打印分数

思路:问题1.如何对分数约分。分子分母各除以他们的最大公约数
      问题2.加减乘除运算
	       加:通分后加结果再约分
		   减:通分后减结果再约分
		   乘:分子乘以分子,分母乘以分母,然后约分。
		   除:除就等于乘以一个数的倒数。
	  问题3.浮点式打印  分子除以分母*/
#include <iostream>
using namespace std;

int gcd(int a,int b){
	if(b)//b!=0时递归,用辗转相除发计算最大公约数
		return gcd(b,a%b);
	return a;//b==0,此时a即为最大公约数
}
class fraction
{
public:
	fraction():numerator(1),denominator(1){}
	fraction(int x,int y){numerator=x;denominator=y;}
	fraction Add(fraction &a);
	fraction Sub(fraction &a);
	fraction Mul(fraction &a);
	fraction Div(fraction &a);
	void Print(){cout<<"分数显示"<<numerator<<"/"<<denominator<<endl;cout<<"浮点数显示"<<(float)numerator/(float)denominator<<endl;}
private:
	int numerator;
	int denominator;
};
fraction fraction::Add(fraction &a)
{
	fraction c;
	c.denominator=a.denominator*denominator;
	c.numerator=c.denominator/a.denominator*a.numerator+c.denominator/denominator*numerator;
	int gys=gcd(c.denominator,c.numerator);
	c.denominator/=gys;
	c.numerator/=gys;
	return c;
}

//以下函数的实现同上

int main()
{
	int x,y;
	cout<<"请输入分子,和分母"<<endl;
	cin>>x>>y;
	fraction a(x,y);
	int m,n;
	cout<<"请输入分子,和分母"<<endl;
	cin>>m>>n;
	fraction b(m,n);
	a.Print();
	b.Print();
	a.Add(b).Print();
	return 0;
}


相关文章
|
网络协议 Linux
SNAT和DNAT原理及应用
SNAT和DNAT原理及应用
2055 0
SNAT和DNAT原理及应用
|
数据采集 SQL 运维
巧用指标平台DataIndex,五步法轻松实现指标管理
在业务发展初期,企业需要做好规范的指标管理,以保证随着业务的不断发展,数据化决策能够成为业务强有力的支撑。本文将为大家详解如何通过袋鼠云指标管理平台DataIndex 进行规范化的指标开发管理,轻松开发指标,避免各类指标问题。
1524 0
|
设计模式 缓存 监控
【Hystrix技术指南】(7)故障切换的运作流程原理分析(含源码)
【Hystrix技术指南】(7)故障切换的运作流程原理分析(含源码)
420 0
【Hystrix技术指南】(7)故障切换的运作流程原理分析(含源码)
|
存储 缓存 运维
阿里云Elasticsearch日志场景最佳实践及引擎内核优化
本文整理自阿里巴巴技术专家郭嘉梁(梁楹)在 阿里云Elasticsearch 自研引擎年度发布 的演讲。
1573 0
阿里云Elasticsearch日志场景最佳实践及引擎内核优化
|
Java easyexcel
Java——使用EasyExcel导出动态列的Excel
Java——使用EasyExcel导出动态列的Excel
|
SQL 存储 缓存
原来count(*)就是我们系统的接口性能变差100倍的真凶…
原来count(*)就是我们系统的接口性能变差100倍的真凶…
|
存储 NoSQL 网络协议
深入解析redis cluster gossip机制
社区版redis cluster是一个P2P无中心节点的集群架构,依靠gossip协议传播协同自动化修复集群的状态。本文将深入redis cluster gossip协议的细节,剖析redis cluster gossip协议机制如何运转。
8504 0