第三周任务三之分数类运算符的重载

和任务2遇到了相似的问题,看不出来了...

源程序:

/*(文件注释头部开始) 
*程序的版权和版本声明部分 
*Copyright (c) 2011,烟台大学计算机学院学生 
*All rights reserved. 
*文件名称:分数类运算符的重载
*作    者:2011级计114-3张宗佳 
*完成日期:2011年4月11号 
*版本号:vc
* 对任务及求解方法的描述部分 
* 输入描术:
* 问题描述:实现分数类中的运算符重载,在分数类中可以完成分数的加减乘除(运算后再化简)、求反、比较(6种关系)的运算。
* 程序输出:
* 程序头部的注释结束 
*/  
#include<iostream>

using namespace std;

int gcd(int a,int b);
class CFraction
{
private:
	int nume;  // 分子
	int deno;  // 分母
public:
	//构造函数及运算符重载的函数声明
	CFraction(int nu = 0,int de = 1);  

	CFraction operator + (CFraction &c1);
	CFraction operator - (CFraction &c1);
	CFraction operator * (CFraction &c1);
	CFraction operator / (CFraction &c1);

	bool operator > (CFraction &c1);
	bool operator < (CFraction &c1);
	bool operator >= (CFraction &c1);
	bool operator <= (CFraction &c1);
	bool operator = (CFraction &c1);
	bool operator != (CFraction &c1);
	CFraction operator - ();//求反

	void Simplify();				

	void output();	

};
//重载函数的实现及用于测试的main()函数
CFraction::CFraction(int nu,int de) 
{
	nume = nu;

	deno = de;
}

CFraction CFraction::operator + (CFraction &c1)
{
	CFraction c;

	c.nume = deno * c1.nume + nume * c1.deno;

	c.deno = deno * c1.deno;

	c.Simplify();

	return c;
}

CFraction CFraction::operator - (CFraction &c1)
{
	CFraction c;

	c.nume = nume * c1.deno - deno * c1.nume;

	c.deno = deno * c1.deno;

	c.Simplify();

	return c;
}
CFraction CFraction::operator * (CFraction &c1)
{
	CFraction c;

	c.nume = nume * c1.nume;

	c.deno = deno * c1.deno;

	c.Simplify();

	return c;
}

CFraction CFraction::operator / (CFraction &c1)
{
	CFraction c;

	c.nume = nume * c1.deno;

	c.deno = deno * c1.nume;

    c.Simplify();

	return c;
}
bool CFraction::operator > (CFraction &c1)
{
	if(nume * c1.deno > deno * c1.nume)
	{
		return true;
	}
	else 
	{
		return false;
	}
}
bool CFraction::operator < (CFraction &c1)
{
	if(nume * c1.deno < deno * c1.nume)
	{
		return true;
	}
	else 
	{
		return false;
	}
}
bool CFraction::operator >= (CFraction &c1)
{
	if(nume * c1.deno < deno * c1.nume)
	{
		return false;
	}
	else 
	{
		return true;
	}
}

bool CFraction::operator <= (CFraction &c1)
{
	if(nume * c1.deno > deno * c1.nume)
	{
		return false;
	}
	else 
	{
		return true;
	}
}
bool CFraction::operator = (CFraction &c1)
{
	if(nume * c1.deno == deno * c1.nume)
	{
		return true;
	}
	else 
	{
		return false;
	}
}
bool CFraction::operator != (CFraction &c1)
{
	if(nume * c1.deno != deno * c1.nume)
	{
		return true;
	}
	else 
	{
		return false;
	}
}
//求反
CFraction CFraction::operator - ()
{
	return 	CFraction(-nume,deno);
}
	


void CFraction::Simplify()
{
	int t,n,d;

	n = nume;

	d = deno; 

	while(n > 0)
	{
		t = d % n;
		d = n;
		n = t;
	}
	nume = nume / n;
	deno = deno / n;
	return;
}

void CFraction::output()
{
	cout << nume << "/" << deno << endl;
}
void main()
{
	CFraction c1(3,5),c2(4,7),c3;

	cout << "c1=";
	c1.output();

	cout << "c2=";
	c2.output();

	c3 = c1 + c2;
	cout << "c1+c2=";
	c3.output();

	c3 = c1 - c2;
	cout << "c1-c2=";
	c3.output();

	c3 = c1 * c2;
	cout << "c1*c2=";
	c3.output();

	c3 = c1 / c2;
	cout << "c1/c2=";
	c3.output();

	cout<<"下面比较两个分数的大小:\n";
	if (c1 > c2) cout << "t1>t2" << endl;
	if (c1 < c2) cout << "t1<t2" << endl;
	if (c1 = c2) cout << "t1=t2" << endl; 
	if (c1 != c2) cout << "t1≠t2" << endl;
	if (c1 >= c2) cout << "t1≥t2" << endl;
	if (c1 <= c2) cout << "t1≤t2" << endl;

	c3 = - c1;
	cout << "c1的相反数是:";
	c3.output();

	system("pause");
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值