关闭

第五周作业任务二

247人阅读 评论(1) 收藏 举报
#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;
}


上级感言:这次任务是在老师讲解后完成的,体会到很多,思路也清晰了不少。 
0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:24901次
    • 积分:826
    • 等级:
    • 排名:千里之外
    • 原创:63篇
    • 转载:0篇
    • 译文:0篇
    • 评论:16条
    最新评论