分数计算器 C++ 实现分数计算、分数排序

这是学校作业,做了就直接发上来了。

可以根据自己需要改。


#include<iostream>
#include<string>
#include<vector>
#include<functional>
#include<algorithm>
using namespace std;

class Fraction
{
public:
	//无参造函数
	Fraction() : numer(0), deno(1)
	{
	}

	//带参造函数
	Fraction(int n, int d) : numer(n), deno(d)
	{
		if (d == 0)
		{
			cerr << "The deno can't be zero!" << endl;
			exit(-1);
		}
	}

	//复制造函数
	Fraction(const Fraction& f) : numer(f.numer), deno(f.deno)
	{
	}

	//设置分数的分子和分母
	void setFraction(int n, int d)
	{
		numer = n;
		deno = d;
	}

	//获取分数的分子
	int getNumer()
	{
		return numer;
	}

	//获取分数的分母
	int getDeno()
	{
		return deno;
	}

	//获取最大公约数 
	int Gcd(int numer, int deno) const
	{
		if (deno == 0) return numer;
		return Gcd(deno, numer % deno);
	}

	//当前分数约分
	void RdcFrc()
	{
		int share = Gcd(numer, deno);
		if (share != 0)
		{
			deno /= share;
			numer /= share;
		}
		else
		{
			cerr << "Failed to execute RdcFrc." << endl;
			exit(-1);
		}
	}

private:
	int numer; //分子
	int deno;  //分母

	//重载+运算符
	friend Fraction operator+(const Fraction& frac1, const Fraction& frac2)
	{
		Fraction result;
		result.numer = frac1.numer * frac2.deno + frac2.numer * frac1.deno;
		result.deno = frac1.deno * frac2.deno;
		result.RdcFrc();
		return result;
	}

	friend Fraction operator-(const Fraction& frac1, const Fraction& frac2) //重载-运算符
	{
		Fraction result;
		result.numer = frac1.numer * frac2.deno - frac2.numer * frac1.deno;
		result.deno = frac1.deno * frac2.deno;
		result.RdcFrc();
		return result;
	}
	friend Fraction operator*(const Fraction& frac1, const Fraction& frac2) //重载*运算符
	{
		Fraction result;
		result.numer = frac1.numer * frac2.numer;
		result.deno = frac1.deno * frac2.deno;
		result.RdcFrc();
		return result;
	}
	friend Fraction operator/(const Fraction& frac1, const Fraction& frac2) //重载/运算符
	{
		Fraction result;
		result.numer = frac1.numer * frac2.deno;
		result.deno = frac1.deno * frac2.numer;
		// 除以0的情况

		result.RdcFrc();
		return result;
	}
	friend bool operator==(const Fraction& frac1, const Fraction& frac2)                  //重载==运算符
	{
		Fraction _frac1 = frac1;
		Fraction _frac2 = frac2;
		_frac1.RdcFrc();
		_frac2.RdcFrc();
		return (_frac1.numer == _frac2.numer && _frac1.deno == _frac2.deno);
	}
	friend bool operator>(const Fraction& frac1, const Fraction& frac2)     //重载>运算符
	{
		return (double(frac1.numer) / frac1.deno > double(frac2.numer) / frac2.deno);
	}
	friend bool operator<(const Fraction& frac1, const Fraction& frac2)     //重载<运算符
	{
		return (double(frac1.numer) / frac1.deno < double(frac2.numer) / frac2.deno);
	}

	friend ostream& operator<<(ostream& out, const Fraction& frac)          //重载<<运算符
	{
		cout << frac.numer << '/' << frac.deno;
		return out;
	}
	friend istream& operator>>(istream& in, Fraction& frac)                 //重载>>运算符
	{
		char split;  // 分数线
		in >> frac.numer >> split >> frac.deno;
		// 检查分母 分数线'/'
		return in;
	}

	//friend void sortFraction(参数列表自行设计);//对分数数组排序

	friend void new_sort(vector<Fraction>& vec, char sign)
	{
		if (sign == '>')
		{
			sort(vec.begin(), vec.end(), greater<>());
		}
		else
		{
			sort(vec.begin(), vec.end(), less<>());
		}
	}

};  // class Fraction


void jiemian1()
{
	while (1)
	{
		cout << "请输入分数计算式(如1/2+1/3回车),输入#号键返回上一层目录:" << endl;
		char ex1;
		char sign;
		Fraction frac1, frac2;
		cin >> frac1 >> sign >> frac2;
		while (cin.fail()) {

			cin.clear();
			if (cin.peek() == '#') 
			{
				getchar();
				system("cls");
				return;
			}
			cin.ignore(INT_MAX, '\n');
			cout << "输入错误!请重新输入:" << endl;
			cin >> frac1 >> sign >> frac2;
		}
		// 应该判断有没有fail再clear
		// 如果输入# cin::failbit变为true,输入被跳过,clear函数恢复该属性

		Fraction result;
		if (sign == '+')
		{
			result = frac1 + frac2;
		}
		else if (sign == '-')
		{
			result = frac1 - frac2;
		}
		else if (sign == '*')
		{
			result = frac1 * frac2;
		}
		else if (sign == '/')
		{
			result = frac1 / frac2;
		}

		cout << "=" << result << endl;
	}
}
void jiemian2()
{
	while (1)
	{
		cout << "请输入一组分数,用逗号隔开,如需由小到大排序用符号<结尾,由大到小排序用符号>结尾(如1/2,1/4,3/5<回车),输入#号键返回上一层目录:" << endl;

		vector<Fraction> vec;
		Fraction tmp;
		char sign;
		while (1)
		{
			cin >> tmp >> sign;
			while (cin.fail() || (sign != ','&&sign != '>'&&sign != '<')) 
			{
				cin.clear();
				if (cin.peek() == '#')
				{
					getchar();
					system("cls");
					return;
				}
				cout << "输入错误!请重新输入:" << endl;
				cin.ignore(INT_MAX, '\n');
				cin >> tmp >> sign;
			}

			vec.push_back(tmp);
			if (sign == '>' || sign == '<')
			{
				break;
			}
		}

		new_sort(vec, sign);
		for (auto& item : vec)
		{
			cout << item << ' ';
		}
		cout << endl;
	}
}

void jiemian()
{
	while (1)
	{
		cout << "1. 分数运算" << endl;
		cout << "2. 分数排序" << endl;
		int c1;
		cin >> c1;
		while (cin.fail()) {
			cout << "输入错误!请重新输入:" << endl;
			cin.clear();
			void jiemian();
			cin.ignore(INT_MAX, '\n');
			cin >> c1;
		}
		if (c1 == 1)
		{
			system("cls");
			jiemian1();
		}
		else if (c1 == 2)
		{
			system("cls");
			jiemian2();
		}
		else
		{
			break;
		}
	}
}
int main()
{
	while (1)
	{
		system("cls");
		jiemian();
	}
	return 0;
}

  • 22
    点赞
  • 80
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
分数计算器C是一种大家都常用的小型软件,主要功能是支持分数的四则运算和求最大公约数。以下是一份分数计算器C的程序代码: #include <stdio.h> #include <stdlib.h> // 分数结构体 typedef struct Fraction{ int numerator; // 分子 int denominator; // 分母 }Fraction; // 求最大公约数 int gcd(int a, int b){ return b == 0 ? a : gcd(b, a % b); } // 约分 Fraction reduce(Fraction f){ if(f.numerator == 0){ // 如果分子为0,分母置为1 f.denominator = 1; }else{ int d = gcd(abs(f.numerator), abs(f.denominator)); f.numerator /= d; f.denominator /= d; } return f; } // 加法 Fraction add(Fraction f1, Fraction f2){ Fraction sum; sum.numerator = f1.numerator * f2.denominator + f2.numerator * f1.denominator; sum.denominator = f1.denominator * f2.denominator; return reduce(sum); } // 减法 Fraction substract(Fraction f1, Fraction f2){ Fraction diff; diff.numerator = f1.numerator * f2.denominator - f2.numerator * f1.denominator; diff.denominator = f1.denominator * f2.denominator; return reduce(diff); } // 乘法 Fraction multiply(Fraction f1, Fraction f2){ Fraction product; product.numerator = f1.numerator * f2.numerator; product.denominator = f1.denominator * f2.denominator; return reduce(product); } // 除法 Fraction divide(Fraction f1, Fraction f2){ Fraction quotient; quotient.numerator = f1.numerator * f2.denominator; quotient.denominator = f1.denominator * f2.numerator; return reduce(quotient); } int main(){ Fraction f1 = {1, 2}; Fraction f2 = {2, 3}; // 加法 Fraction f3 = add(f1, f2); printf("%d/%d + %d/%d = %d/%d\n", f1.numerator, f1.denominator, f2.numerator, f2.denominator, f3.numerator, f3.denominator); // 减法 Fraction f4 = substract(f1, f2); printf("%d/%d - %d/%d = %d/%d\n", f1.numerator, f1.denominator, f2.numerator, f2.denominator, f4.numerator, f4.denominator); // 乘法 Fraction f5 = multiply(f1, f2); printf("%d/%d * %d/%d = %d/%d\n", f1.numerator, f1.denominator, f2.numerator, f2.denominator, f5.numerator, f5.denominator); // 除法 Fraction f6 = divide(f1, f2); printf("%d/%d ÷ %d/%d = %d/%d\n", f1.numerator, f1.denominator, f2.numerator, f2.denominator, f6.numerator, f6.denominator); return 0; } 以上是分数计算器C的程序代码,通过运行该程序可以实现分数的加减乘除运算,并且支持自动约分和求最大公约数功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值