第5周实验报告任务2

 /* (程序头部注释开始)

* 程序的版权和版本声明部分

* Copyright (c) 2011, 烟台大学计算机学院学生

* All rights reserved.* 文件名称: 分数

* 作 者: 郭岩岩

* 完成日期: 2012年 3月 18日

* 版 本 号: vc.1

* 对任务及求解方法的描述部分

*输入描述:

 * 问题描述:

* 程序输出:

 * 程序头部的注释结束

*/

#include<iostream>
using namespace std;
class CFraction
{
private:
	int nume;  // 分子
	int deno; // 分母
	int M;    //以备几又几分之几之用 
 public:
	CFraction(int nu=0,int de=1,int m=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;
	void Calculation_m();



							//style为1时,输出4/3;
							//style为2时,输出1(1/3),表示一又三分之一;
							//不给出参数和非1、2,认为是方式0
};
CFraction::CFraction(int nu,int de,int m)
{
	nume=nu;
	deno=de;
	M=m;
}
void CFraction::Set(int nu,int de)
{
	nume=nu;
	deno=de;
}
void CFraction::input()
{
	cout<<nume<<"/"<<deno;
}
void CFraction::Simplify()
{
	int n,t1,t2,i;
	if(nume%deno==0)
	{
		deno=1;
		nume=nume%deno;
	}
	if(deno%nume==0)
	{
		nume=1;
		deno=deno%nume;
	}

	if(nume>deno)
	{n=deno;
	}
	else
		n=nume;
		for(i=1;i<=n;i++)
		{
			t1=nume%i;
			t2=deno%i;
			if(t1==0&&t2==0)
			{
				nume=nume/i;
				deno=deno/i;              
			}
		}
}
void CFraction::amplify(int n)
{
	nume=nume*n;
  cout<<"放大"<<n<<"倍后为:"<<nume<<"/"<<deno<<endl;
}
void CFraction::output(int style)
{
	if(style==1)
	{
        Simplify();
			cout<<nume<<"/"<<deno<<endl;
	}
	else
		if(style==2)
		{
			Simplify();
			cout<<M<<"("<<nume<<"/"<<deno<<")"<<endl;
		}
		else
			cout<<nume<<"/"<<deno<<endl;
}
void CFraction::Calculation_m()
{
	if(nume>deno)
	{
		M=nume/deno;
		nume=M*(nume-deno);
	}
}
int main()
{
	CFraction cf;
	cf.Set(24,72);
	cf.input();
	//cf.Simplify();
	cf.amplify(5);
	cout<<"style(0):"<<endl;
		cf.output(0);
	cout<<"style(1):"<<endl;
		cf.output(1);
	cout<<"style(2):"<<endl;
    cf.Calculation_m();
	cf.output(2);
	return 0;
}




 

上机感言:这个程序快把我绕晕了,老师帮我看一下化简时的算法对不对

经验积累:在定义时参数不能赋值,不然会出错!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值