实验目的:任务要求:完成下面类的设计,并在main()函数中自定义对象,调用各成员函数,完成基本的测试
实验代码:
#include<iostream>
using namespace std;
class CFraction
{
private:
int nume; // 分子
int deno; // 分母
public:
CFraction(int, int); //构造函数,初始化用
void Set(int nu, int de); //置值,改变值时用
void input(); //按照"nu/de"的格式,如"5/2"的形式输入
void Simplify(); //化简(使分子分母没有公因子)
void amplify(int n); //放大n倍,如"2/3"放大5倍为"10/3"
void output(int style); //输出:以"8/6"为例,style为0时,输出8/6;
//style为1时,输出4/3
//style为2时,输出1(1/3),表示一又三分之一;
//不给出参数和非1、2认为是方式0
};
void main()
{
CFraction cf(0, 1);
cf.Set(6, 8);
cf.input();
cf.Simplify();
int n;
cout << "请输入您想在原有分数基础上扩大的倍数: ";
cin >> n;
cf.amplify(n);
cout << endl;
int style;
cout << "输入0,原分数以原有形式输出; 输入1,原分数以最简形式输出; 输入2,原分数以假分数形式输出; 不输入数值或者输入非0、1、2,原分数以原有形式输出: ";
cin >> style;
cf.output(style);
}
CFraction::CFraction(int nu = 0, int de = 1)
{
nume = nu;
deno = de;
}
void CFraction::Set(int nu, int de)
{
nume = nu;
deno = de;
}
void CFraction::input()
{
cout << nume << "/" << deno << endl;
}
void CFraction::Simplify()
{
int a[10];
for(int i = 1, j = 0; i <= nume; i++)
{
if(nume % i == 0)
{
a[j] = i;
j++;
}
}
//定义a[10]数组用于存储nume的因数
int b[10];
for(int n = 1, m = 0; n <= deno; n++)
{
if(deno % n == 0)
{
b[m] = n;
m++;
}
}
//定义b[10]数组用于存储deno的因数
for(int k = 0; k <= (j - 1); k++)
{
for(int p = 0; p <= (m - 1); p++)
{
if(a[k] == b[p])
{
nume = nume / a[k];
deno = deno / a[k];
}
}
}
cout << nume << "/" << deno << endl;
}
void CFraction::amplify(int n)
{
nume = nume * n;
cout << nume << "/" << deno;
}
void CFraction::output(int style)
{
switch(style)
{
case 0: cout << nume << "/" << deno << endl; break;
case 1:Simplify(); break;
case 2: if(nume < deno) cout << nume << "/" << deno; else cout << nume / deno << "(" << nume - (nume / deno) * deno << "/" << deno << ")" << endl; break;
default: cout << nume << "/" << deno << endl; break;
}
}
实验结果截图:
实验心得:
看似有难度,其实只是输出时用点小技巧就好了,对于现在的我们不还是小菜一盘嘛!可是倒是真的遇见一些问题了,在化简分数的时候,稍微有了一点麻烦,因为在我的代码中,是用数组存储分子和分母的约数,然后再寻找公共项,加以消除,得最简形势,因为稍微需要一些逻辑思考,所以很容易出错,所以我用了一些标注,感觉还是挺好的,能提醒自己一部分代码是做什么用的,用标注,的确是可以使调理清晰啦,所以老师说的没错,一则代码好不好,标注很重要。至于代码上还是着重考察构造函数,熟练之后,应该是比较容易上手的。