#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(); //按照"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;
//style为2时,输出1(1/3)形式,表示一又三分之一;
//style为3时,用小数形式输出,如1.3333;
//默认方式0
};
CFraction::CFraction(int nu,int de)
{
if (de!=0)
{
nume=nu;
deno=de;
}
else
{
cerr<<"程序初始化错误,程序退出。"<<endl;
exit(0);
}
}
void CFraction::set(int nu,int de)
{
if (de!=0)
{
nume=nu;
deno=de;
}
}
void CFraction::input()
{
int nu,de;
char x;
do
{
cin>>nu>>x>>de;
if (x!='/')
{
cout<<"输入格式有误,请重新输入:";
continue;
}
else if (de==0)
{
cout<<"分母不能为0,请重新输入:";
continue;
}
else
{
break;
}
}
while (1);
nume=nu;
deno=de;
}
void CFraction::simplify()
{
int n=gcd(nume,deno);
nume/=n;
deno/=n;
}
int gcd(int x, int y) //求最大公约数
{
int z;
while (y!=0)
{
z=x;
x=y;
y=z%y;
}
return x;
}
void CFraction::amplify(int n)
{
nume*=n;
}
void CFraction::output(int style)
{
int n;
switch (style)
{
case 0:
cout<<"原样输出: "<<nume<<"/"<<deno<<endl;
break;
case 1:
n=gcd(nume,deno);
cout<<"化简后输出: "<<nume/n<<"/"<<deno/n<<endl;
break;
case 2:
n=gcd(nume,deno);
cout<<"带分数形式: "<<nume/deno<<"("<<(nume%deno)/n<<"/"<<deno/n<<")"<<endl;
break;
case 3:
cout<<"小数形式: "<<nume/(double)deno<<endl;
break;
default:
cout<<"默认方式输出: "<<nume<<"/"<<deno<<endl;
}
}
int main()
{
CFraction a,b(8,6);
cout<<"对于a:";
a.output();
cout<<"改变a:";
a.set(10,6);
a.output();
a.output(2);
cout<<"放大a:";
a.amplify(5);
a.output();
cout<<"输入a:";
a.input();
a.output();
a.output(3);
cout<<endl;
cout<<"对于b: ";
b.output(0);
b.output(1);
b.output(2);
b.output(3);
b.output();
cout<<"化简b:";
b.simplify();
b.output();
cout<<"放大b:";
b.amplify(2);
b.output();
return 0;
}
炸了,看了刘畅的博文。似乎还是有许多不明白,回头有空再研究研究。