第五周作业任务二

#include <iostream>   
using namespace std;  
int gcd(int,int);    
class CFraction  
{private:  
int nume;//分子     
int deno;//分母     
public:  
      CFraction(int nu = 0,int de = 1);//构造函数,初始化用   
  
      void set(int nu = 0,int de = 1);//置值,改变值时用   
  
      void input();//按照"nu/de"的格式,如"5/2"的形式输入   
 
      void Simplify();//化简(是分子分母没有公因子)   
  
      void amplify(int n);//放大n倍,如2/3放大五倍为10/3   
  
      void output(int style = 0);//输出:以8/6为例,style为0时,输出8/6; 
	  
	                             //style为1时,输出4/3;   

                               //style为2时,输出1(1/3),表示一又三分之一;   
                               //不给出参数和非1、2,认为是方式0
};
 CFraction::CFraction(int nu,int de)
{
	if(de!=0)
	{
		nume=nu;
		deno=de;
	}
	else
	{
		cerr<<"分母不能为0"<<endl;
		exit(0);
	}
}
 void CFraction::set(int nu,int de)
 {
	 if(de!=0)
	 {nume=nu;
	 deno=de;
	 }
 }
void CFraction::input()
{
	char c;
	while(1)
	{
		cin>>nume>>c>>deno;
        if(c!='/')
			cout<<"格式不对"<<endl;
		    else if(deno==0)
				cout <<"分母不能为0"<<endl;
			else 
				break;
	}
}
void CFraction::Simplify()
{   
	int n=gcd(nume,deno);
	nume=nume/n;
	deno=deno/n;
}
//求最大公约数
int gcd(int x,int y)
{
	int r;
    while(y!=0)
	{
	r=x%y;
	x=y;
	y=r;
	}
 return x;
}
void CFraction::amplify(int n)
{
	nume*=n;//分子放大n倍
}
void output(int style=0)
{
	int i,nu,de,nume,deno;
	switch(style)
	{
	case 0:
		cout<<nume<<'/'<<deno<<endl;
		break;
	case 1:
		 i=gcd(nume,deno);
		cout<<(nume/i)<<'/'<<(deno/i)<<endl;
		break;
	case 2:
		i=gcd(nume,deno);
		nu=nume/i;
		de=deno/i;
		cout<<(nu/de)<<"("<<(nu%de)<<'/'<<de<<")"<<endl;
		break;
	default:
		cout<<nume<<'/t'<<deno<<endl;
	}
}
int main()
{
	CFraction c1;
	c1.output(0);
	c1.amplify(5);
	c1.output(0);
	c1.set(8,6);
	system("pause");
	return 0;
}


上级感言:这次任务是在老师讲解后完成的,体会到很多,思路也清晰了不少。 
阅读更多
上一篇第五周作业任务一
下一篇周五任务三
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭