C++第5周任务【任务2】本任务将设计一个简单的分数类,完成对分数的几个运算。一则巩固基于对象编程的方法,二则也为第10章做运算符重载等积累些感性认识。

/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生 
* All rights reserved.
* 文件名称:  C++中提供了多种基本的数据类型                            
* 作    者:李洪悬                              
* 完成日期:  2011       年  3     月  20      日
* 版 本 号:          

* 对任务及求解方法的描述部分
* 输入描述: 
* 问题描述: 
* 程序输出: 
* 程序头部的注释结束
*/
【任务2】C++中提供了多种基本的数据类型。实际上,这些远不能满足我们的需求,如复数(第10章的例子大多是处理虚数的),再如分数。本任务将设计一个简单的分数类,完成对分数的几个运算。一则巩固基于对象编程的方法,二则也为第10章做运算符重载等积累些感性认识。
任务要求:完成下面类的设计,并在main()函数中自行定义对象,调用各成员函数,完成基本的测试。
class CFraction
{private:
	int nume;  // 分子
	int deno;  // 分母
 public:
	CFraction(int nu=0,int de=1);   //构造函数,初始化用
	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),表示一又三分之一;
							//不给出参数和非1、2,认为是方式0
};



#include <iostream>

using namespace std;

int gcd(int a,int b);//求最大公约数

class CFraction

{private:
int nume;  // 分子

int deno;  // 分母

public:
	CFraction(int nu=0,int de=1);   //构造函数,初始化用
	
	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),表示一又三分之一;
	//不给出参数和非1、2,认为是方式0
};
int main()
{
	CFraction cf;

	cf.set();

	cf.input();

	cf.simplify();

	cf.amplify(4);

	cf.output(2);

	system ("Pause");

	return 0;

}

//构造函数,初始化用
CFraction::CFraction(int nu,int de)
{
	if (de != 0)
	{
		nume = nu;
		
		deno = de;
	}
	else
	{
		cout << "分母不能为0! " << endl;
		exit(0);//直接退出
	}
	
} 

//置值,改变值时用
void CFraction::set(int nu,int de)
{
	if(de != 0)
	{
		nume = nu;
		
		deno = de;
	}
}
void CFraction::input()
{
	cout << "请输入分数(m/n):" << endl;
	int nu,de;
	while(1)
	{
	
		char c;
		
		cin >> nu >> c >> de;
		
		if(c != '/')
		{
			cout << "输入格式不对!" << endl;
		}
		else if(de == 0)
		{
			cout << "分母不能为0!" << endl;
		}
		else
			break;
	}
	nume = nu;

	deno = de;

}

int gcd(int a, int b)求最大公约数
{
	int c;
	
	while(b != 0)
	{
		c = a % b;
		
		a = b;
		
		b = c;
	}
	return a;
}
void CFraction::simplify()
{
	int t;
	
	t = gcd(nume,deno);
	
	nume = nume / t;
	
	deno = deno / t;
	
}
void CFraction::amplify(int n)放大n倍,如2/3放大5倍为10/3
{
	nume = nume * n;

	cout << nume << '/' << deno << endl;
		
}
void CFraction::output(int style)
{
	int x;
	switch (style)
	{
		
	case 0:
			cout << nume << '/' << deno << endl;
			
	case 1:
			
				x = gcd(nume,deno);
				
				cout << nume / x << '/' << deno / x << endl;
				
				break;
			
	case 2:
			
			 x = gcd(nume,deno);
				
				nume = nume / x;
				
				deno = deno / x;
				
				cout << (nume / deno) << '(' << (nume %deno)<< '/' << deno << ')' << endl;
				
				break;
				
			
	default :
				cout << nume << '/' << deno << endl;
				}
}
				
				
















以下是一个简单的考虑异常情况的分数模板的实现: ```c #include <stdio.h> #include <stdlib.h> template<class T> class Fraction { private: T numerator; // 分子 T denominator; // 分母 public: // 构造函数 Fraction(T num = 0, T den = 1) { if (den == 0) { printf("Error: denominator cannot be zero.\n"); exit(1); } numerator = num; denominator = den; } // 加法运算 Fraction<T> operator+(const Fraction<T>& f) const { T num = numerator * f.denominator + f.numerator * denominator; T den = denominator * f.denominator; return Fraction<T>(num, den); } // 减法运算 Fraction<T> operator-(const Fraction<T>& f) const { T num = numerator * f.denominator - f.numerator * denominator; T den = denominator * f.denominator; return Fraction<T>(num, den); } // 乘法运算 Fraction<T> operator*(const Fraction<T>& f) const { T num = numerator * f.numerator; T den = denominator * f.denominator; return Fraction<T>(num, den); } // 除法运算 Fraction<T> operator/(const Fraction<T>& f) const { if (f.numerator == 0) { printf("Error: divide by zero.\n"); exit(1); } T num = numerator * f.denominator; T den = denominator * f.numerator; return Fraction<T>(num, den); } // 输出分数 void print() const { printf("%d/%d\n", numerator, denominator); } }; int main() { Fraction<int> f1(1, 2); Fraction<int> f2(2, 3); Fraction<int> f3 = f1 + f2; f3.print(); // 输出 7/6 Fraction<int> f4 = f1 - f2; f4.print(); // 输出 -1/6 Fraction<int> f5 = f1 * f2; f5.print(); // 输出 1/3 Fraction<int> f6 = f1 / f2; f6.print(); // 输出 3/4 Fraction<int> f7(1, 0); // 分母为零,会输出异常信息并退出程序 Fraction<int> f8 = f1 / f7; return 0; } ``` 在这个实现中,我们定义了一个模板 `Fraction<T>`,其中 `T` 是分数型,可以是任何支持运算符的型,如 `int`、`double` 等。在构造函数中,我们检查分母是否为零,如果是,则输出异常信息并退出程序。在运算符重载中,我们对于除法运算还检查了除数是否为零。在输出分数时,我们简单地输出分子和分母即可。在 `main` 函数中,我们定义了一些分数并进行了加减乘除运算,同时也测试了当分母为零时的异常情况。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值