第九周实验报告(三)

/* (程序头部注释开始)

* 程序的版权和版本声明部分

* Copyright (c) 2011, 烟台大学计算机学院学生 

* All rights reserved.

* 文件名称:定义CTime类中的<<和>>运算符重载,实现时间的输入输出,改造原程序中对运算结果显示方式,使程序读起来更自然。

* 作    者:        李腾                       

* 完成日期:     2012    年 04  月  16 日

* 版 本 号:       V1.0   

* 对任务及求解方法的描述部分

* 输入描述: 

* 问题描述: 

* 程序输出:

 * 程序头部的注释结束

*/
 
  
#include 
using namespace std;
class CFraction
{
private:
	int nume;  // 分子
	int deno;  // 分母
public:
	CFraction(int nu=0,int de=1):nume(nu),deno(de){}
	void simplify();

	//输入输出的重载
	friend istream &operator>>(istream &in,CFraction &x);
	friend ostream &operator<<(ostream &out,CFraction x);
	
	CFraction operator+(const CFraction &c);  //两个分数相加,结果要化简
	CFraction operator-(const CFraction &c);  //两个分数相减,结果要化简
	CFraction operator*(const CFraction &c);  //两个分数相乘,结果要化简
	CFraction operator/(const CFraction &c);  //两个分数相除,结果要化简
	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::simplify()
{
	int m,n,r;
	m=abs(deno);
	n=abs(nume);
	while(r=m%n)  // 求m,n的最大公约数
	{
		m=n;
		n=r;
	}
	deno/=n;     // 化简
	nume/=n;
	if (deno<0)  // 将分母转化为正数
	{
		deno=-deno;
		nume=-nume;
	}
}

// 重载输入运算符>>
istream &operator>>(istream &in,CFraction &x)
{
	char ch;
	while(1)
	{
		cout<<"请按以下格式输入m/n"<>x.nume>>ch>>x.deno;
		if (x.deno==0) 
			cerr<<"分母为! 请重新输入\n";
		else if(ch!='/')
			cerr<<"格式错误(形如m/n)! 请重新输入\n";
		else
			break;
	}
	return cin;
}

// 重载输出运算符<<
ostream &operator<<(ostream &out,CFraction x)
{
	cout<(const CFraction &c)
{
	int this_nume,c_nume,common_deno;
	this_nume=nume*c.deno;        // 计算分数通分后的分子,同分母为deno*c.deno
	c_nume=c.nume*deno; 
	common_deno=deno*c.deno;
	if ((this_nume-c_nume)*common_deno>0) return true;
	return false;
}

// 分数比较大小
bool CFraction::operator<(const CFraction &c)
{
	int this_nume,c_nume,common_deno;
	this_nume=nume*c.deno;      
	c_nume=c.nume*deno;
	common_deno=deno*c.deno;
	if ((this_nume-c_nume)*common_deno<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 || *this=(const CFraction &c)
{
	if (*thisc) return false;
	return true;
}

int main()
{
	CFraction x,y,s;
	cout<<"输入x: ";
	cin>>x;
	cout<<"输入y: ";
	cin>>y;
	s=+x+y;
	cout<<"+x+y="<


  
  
 
  
 
 

你可能感兴趣的:(c++作业)