/*
*Copyright (c) 2014, 烟台大学计算机学院
*All rights reserved.
*文件名称:test.cpp
*作者:于凯
*完成日期:2015年4月6日
*版本号:v1.0
*
*/
#include <iostream>
#include<Cmath>
#include<cstdlib>
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();
void simplify();
void amplify(int n);
void output(int style=0);
};
CFraction::CFraction(int nu,int de)
{
if(de==0)
{
cout<<"数值错误,程序退出。";
exit(0);
}
else
{
deno=de;
nume=nu;
}
}
void CFraction::set(int nu,int de)
{
if(de!=0)
{
deno=de;
nume=nu;
}
}
void CFraction::input()
{
int de,nu;
while(1)
{
cout<<"输入分子分母,注意顺序!";
cin>>nu>>de;
if(de==0)
cout<<"分母不能为零!"<<endl;
else
break;
}
deno=de;
nume=nu;
}
void CFraction::simplify()
{
int z;
z=gcd(nume,deno);
nume=nume/z;
deno=deno/z;
}
int gcd(int x,int y)
{
int r;
if(y!=1)
while(r==0)
{
y=x;
x=r;
r=y%x;
}
return x;
}
void CFraction::amplify(int n)
{
nume=nume*n;
}
void CFraction::output(int style)
{
switch(style)
{
case 0:
cout<<"原样输出:"<<nume<<'/'<<deno<<endl;
break;
case 1:
cout<<"简化后:"<<gcd(nume,deno)<<endl;
break;
case 2:
cout<<"整数+真分数:"<<nume/deno<<'('<<(nume-deno*(nume/deno))<<'/'<<deno<<')'<<endl;
break;
case 3:
cout<<"小数形式:"<<nume/double(deno)<<endl;
break;
}
}
int main()
{
CFraction c1;
c1.input();
c1.output(0);
c1.output(1);
c1.output(2);
c1.output(3);
return 0;
}
运行结果: