建立一个分数类 Fraction,分数类的数据成员包括分子和分母,成员函数包括构造函数、 复制构造函数。

本文介绍了一个C++实现的分数类,包含构造函数、约分、通分、加减乘除、求倒数、比较大小等操作。特别地,复制构造函数用于生成分数的倒数。此外,还提供了友元函数来实现分数的输入和输出。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

构造函数对初始化数据进行了必要的检查(分母不能为 0)。将分数显示成“a/b” 形式的输出函数。成员函数包括约分、通分、加、减、乘、除、求倒数、比较大小、显示和输入。

其中的复制构造函数是直接复制为倒数,由于不想再写一个构造函数,每次想复制相同的分数就调用了两次复制构造函数。

# include<iostream>
using namespace std;
class Fraction
{
	int mol;//分子
	int den;//分母
public:
	Fraction(int m, int d);
	//约分
	void divide();
	//通分
	void gen(Fraction& f);
	//加
	friend Fraction add(Fraction& a, Fraction& b);
	//减
	friend Fraction red(Fraction& a, Fraction& b);
	//乘
	friend Fraction mul(Fraction& a, Fraction& b);
	//除
	friend Fraction div(Fraction& a, Fraction& b);
	//求倒数,用的复制构造函数直接复制成倒数
	Fraction(const Fraction& f);
	//比较大小
	friend void judge(Fraction& a, Fraction& b);
	//显示
	void print();
	//输入
	friend Fraction input();
};

Fraction::Fraction(int m, int d)
{
	mol = m;
	den = d;
	while (d == 0)
	{
		cout << "请重新输入分子分母" << endl;
		cin >> m >> d;
		mol = m;
		den = d;
	}
}

void Fraction::divide()
{
	int t, a, b;
	a = mol;
	b = den;
	while (b != 0)
	{
		t = a % b;
		a = b;
		b = t;
	}
	mol = mol / a;
	den = den / a;
}

void Fraction::gen(Fraction& f)
{
	mol = mol * f.den;
	den = den * f.den;
}

Fraction::Fraction(const Fraction& f)
{
	mol = f.den;
	den = f.mol;
}

void Fraction::print()
{
	divide();//约分好再输出
	cout << mol << "/" << den << endl;
}

Fraction add(Fraction& a, Fraction& b)
{
	Fraction f1(a);
	Fraction f2(f1);//f2与a相同
	Fraction f3(b);
	Fraction f4(f3);//f4与b相同
	f2.gen(b);
	f4.gen(a);
	int mol = f2.mol + f4.mol;
	int den = f2.den;
	return Fraction(mol, den);
}

Fraction red(Fraction& a, Fraction& b)
{
	Fraction f1(a);
	Fraction f2(f1);//f2与a相同
	Fraction f3(b);
	Fraction f4(f3);//f4与b相同
	f2.gen(b);
	f4.gen(a);
	int mol = f2.mol - f4.mol;
	int den = f2.den;
	return Fraction(mol, den);
}

Fraction mul(Fraction& a, Fraction& b)
{
	int mol = a.mol * b.mol;
	int den = a.den * b.den;
	return Fraction(mol, den);
}

Fraction div(Fraction& a, Fraction& b)
{
	Fraction c(b);
	int mol = a.mol * c.mol;
	int den = a.den * c.den;
	return Fraction(mol, den);
}

void judge(Fraction& a, Fraction& b)
{
	Fraction f1(a);
	Fraction f2(f1);//f2与a相同
	Fraction f3(b);
	Fraction f4(f3);//f4与b相同
	f2.gen(b);
	f4.gen(a);
	if (f2.mol > f4.mol) cout << a.mol << "/" << a.den << ">" << b.mol << "/" << b.den << endl;
	else if (f2.mol < f4.mol) cout << a.mol << "/" << a.den << "<" << b.mol << "/" << b.den << endl;
	else if (f2.mol == f4.mol) cout << a.mol << "/" << a.den << "=" << b.mol << "/" << b.den << endl;
}

Fraction input()
{
	int mol, den;
	cin >> mol >> den;
	return Fraction(mol, den);
}

主函数的代码就没有放上去。 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值