#include<iostream>
using namespace std;
#include<cstdlib>
#include<ctime>
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放大5倍为10/3
void output(int style=0); //输出:以8/6为例,style为0时,原样输出8/6;
//style为1时,输出化简后形式4/3;
void intfenshu();//style为2时,输出1(1/3)形式,表示一又三分之一;
void xiaoshu();//style为3时,用小数形式输出,如1.3333;
//默认方式0
};
void CFraction::intfenshu()
{
if(nume/deno==0)
cout<<nume<<'/'<<deno<<endl;
else
cout<<nume/deno<<'('<<nume%deno<<'/'<<deno<<')'<<endl;
}
void CFraction::xiaoshu()
{
double r;
r=static_cast<double>(nume*1.0/deno);
cout<<r<<endl;
}
void CFraction::output(int style)
{
switch(style)
{
case 0:
cout<<nume<<'/'<<deno<<endl;
break;
case 1:
simplify();
cout<<nume<<'/'<<deno<<endl;
break;
case 2:
intfenshu();
break;
case 3:
xiaoshu();
break;
}
}
CFraction::CFraction(int nu,int de)
{
nume=nu;
deno=de;
}
void CFraction::input()
{
int a,b;
char line;
cin>>a>>line>>b;
nume=a;
deno=b;
}
void CFraction::simplify()
{
int r,q1,q2,p;
q1=nume;
q2=deno;
while(r!=0)
{
r=nume%deno;
nume=deno;
deno=r;
}
p=nume;
nume=q1/p;
deno=q2/p;
}
void CFraction::amplify(int n)
{
nume=nume*n;
}
int main()
{
int i;
CFraction c1(98,65);
int n;
for(i=0;i<4;i++)
{
srand(time(0));
n=i;
c1.output(n);
}
return 0;
}
第6周项1-分数类雏形
最新推荐文章于 2016-05-19 08:22:13 发布