/*
*程序的版权和版本声明部分:
*Copyright(c)2014,烟台大学计算机学院学生
*All rights reserved.
*文件名称:分数类的构造函数
*作者:刘中林
*完成日期:2013年 3月 25 日
*版本号:v1.0
*对任务及求解方法的描述部分:
*输入描述: 无
*问题描述:设计关于分数的一系列算法
*程序输出:根据提示输出需要的形式
*问题分析:
*算法设计:
*/
#include <iostream>
#include <cstdlib>
using namespace std;
class CFraction
{
private:
int nume; // 分子
int deno; // 分母
public:
CFraction(int nu=0,int de=1):nume(nu),deno(de){} //构造函数,初始化用
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 nu,de;
char a;
cin>>nu>>a>>de;
set(nu,de);
}
void CFraction::simplify()
{
int i,t;
if(nume>deno)
{
t=nume;
}else
{
t=deno;
}
for(i=2;i<=t;i++)
{
while(nume%i==0&&deno%i==0)
{
nume/=i;
deno/=i;
}
}
}
void CFraction::amplify(int n)
{
nume*=n;
}
void CFraction::output(int style)
{
int n;
if(style==0)
{
cout<<nume<<"/"<<deno<<endl;
}else if(style==1)
{
n=nume/deno;
nume=nume-n*deno;
cout<<n<<"("<<nume<<"/"<<deno<<")"<<endl;
}else
{
cout<<double(nume)/double(deno)<<endl;
}
}
int main()
{
CFraction cf;
int n,num;
cout<<"请按照"<<"nu/de"<<"的格式,如"<<"5/2"<<"的形式输入:"<<endl;
cf.input();
while(true)
{
cout<<"请输入您的选择:"<<endl;
cout<<"1.原样输出. 2.化简后输出."<<endl;
cout<<"3.扩大N倍后输出. 4.以假分数形式输出"<<endl;
cout<<"5.以小数形式输出 0.退出."<<endl;
cin>>n;
switch(n)
{
case 0:
exit(0);
case 1:
cf.output();
break;
case 2:
cf.simplify();
cf.output();
break;
case 3:
cout<<"请输入扩大倍数:"<<endl;
cin>>num;
cf.amplify(num);
cf.output();
break;
case 4:
cf.output(1);
break;
case 5:
cf.output(2);
break;
default:
cout<<"输入有误,请重新输入:"<<endl;
cin>>n;
}
}
return 0;
}
*样例输出:
*心得体会:有兄弟、不孤单。。