/*
*程序的版权和版本声明部分:
*Copyright(c)2014,烟台大学计算机学院学生
*All rights reserved.
*文件名称:
*作者:刘晓晓
*完成日期:2014年 03月26号
*版本号:v1.0
*对任务及求解方法的描述部分:
*输入描述: 无
*问题描述:分数类的雏形
*程序输出:无
*问题分析:
*算法设计:
*/
#include <iostream>
#include <cstdlib>
using namespace std;
class CFraction
{
private:
int nume; // 分子
int deno; // 分母
public:
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
};
void CFraction::set(int nu,int de )
{
nume=nu;
deno=de;
}
void CFraction::input()
{
int a,b;
cout<<"请输入一个分数:" <<endl;
char c;
while(1)
{
cin>>a>>c>>b;
if (c!='/')
cout<<"格式不对,请重新输入!"<<endl;
else
break;
}
set(a,b);
}
void CFraction::amplify(int n)
{
nume=nume*n;
}
void CFraction::output(int style)
{
int a;
switch(style)
{
case 0:
cout<< "此分数为:"<<nume<<"/"<<deno<<endl;
break;
case 1:
simplify();
cout<<"化简后的结果为:"<<nume<<"/"<<deno<<endl;
break;
case 2:
cout<<"输出1(1/3)形式"<<endl;
simplify();
a=nume/deno;
cout<<a<<"("<<nume-deno*a<<"/"<<deno<<")"<<endl;
case 3:
cout<<" 用小数形式输出为:"<<endl;
double c;
double x=nume,y=deno;
c=x/y;
cout<<c<<endl;
break;
}
}
void CFraction::simplify()
{
int i;
int t;
if(nume>deno)
t=deno;
else
t=nume;
for(i=2; i<=t; i++)
{
if(nume%i==0&&deno%i==0)
{
nume/=i;
deno/=i;
}
}
}
int main()
{
int n;
CFraction t;
t.input();
t.output(0);
t.output(1);
t.output(2);
t.output(3);
CFraction T;
T.input();
cout<<"输入放大倍数:"<<endl;
cin>>n;
T.amplify(n);
T.output(0);
return 0;
}
鼓捣了一个多小时了!!!!!!!!!