第十五周实验报告2

/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2012, 烟台大学计算机学院学生 
* All rights reserved.
* 文件名称:MFC(计算器)
* 作 者: 于宸
* 完成日期: 2012 年 05 月 30 日
* 版 本 号: 1.072
* 对任务及求解方法的描述部分
* 输入描述: ......
* 问题描述: ......
* 程序输出: ......
* 程序头部的注释结束
*/
CFraction.h:
class CFraction  
{  
private:  
    int nume;  // 分子  
    int deno;  // 分母  
    int gcd(int nu, int de);  
public:  
    //构造函数及运算符重载的函数声明  
    CFraction(int nu = 0, int de = 1);         //构造函数   
    friend CFraction operator + (CFraction &c1,CFraction &c2);  
    friend CFraction operator - (CFraction &c1,CFraction &c2);  
    friend CFraction operator * (CFraction &c1,CFraction &c2);  
    friend CFraction operator / (CFraction &c1,CFraction &c2);  
    int get_nume();  
    int get_deno();  
    void Simplify();                    //化简(使分子分母没有公因子)  
};
CFraction.cpp:
#include"stdafx.h"
#include"CFraction.h"
using namespace std;

CFraction::CFraction(int nu, int de)
{
	nume = nu;
	deno = de;
}

int CFraction::gcd(int nu, int de)    
{    
	int t, r, a, b;   

	a = nu;  

	b = de;  

	if (a < b)       
	{    
		t = a;    
		a = b;                                     
		b = t;    
	}     

	while (b != 0)    
	{    
		r = a % b;    
		a = b;    
		b = r;    
	}    

	return a;    
}  

void CFraction::Simplify() 
{  
	int n ;

	if(nume < 0)
	{
		n = gcd(-nume, deno);
	}
	else
	{
		n = gcd(nume, deno);
	}

	nume = nume / n;  

	deno = deno / n; 

}  

CFraction operator + (CFraction &c1,CFraction &c2)
{
	CFraction c;

	c.nume = c1.nume * c2.deno + c2.nume * c1.deno;

	c.deno = c1.deno * c2.deno;

	return c;
}

CFraction operator - (CFraction &c1,CFraction &c2)
{
	CFraction c;

	c.nume = c1.nume * c2.deno - c2.nume * c1.deno;

	c.deno = c1.deno * c2.deno;

	return c;
}

CFraction operator * (CFraction &c1,CFraction &c2)
{
	CFraction c;

	c.nume = c1.nume * c2.nume;

	c.deno = c1.deno * c2.deno;

	return c;
}

CFraction operator / (CFraction &c1,CFraction &c2)
{
	CFraction c;

	c.nume = c1.nume * c2.deno;

	c.deno = c1.deno * c2.nume;

	return c;
}

int CFraction::get_nume()
{
	return this->nume;
}

int CFraction::get_deno()
{
	return this->deno;
}
分数计算器Dlg.cpp:
void C分数计算器Dlg::OnBnClickedButton1()
{
	// TODO: 在此添加控件通知处理程序代码
	UpdateData(); //将把界面上各控件输入的值“捕获”到与之关联的变量中
	CFraction c1(c1_nume, c1_deno), c2(c2_nume, c2_deno), c(0, 1);

	if(sign == '+')
	{
		c = c1 + c2;
	}
	else if(sign == '-')
	{
		c = c1 - c2;
	}
	else if(sign == '*')
	{
		c = c1 * c2;
	}
	else if(sign == '/')
	{
		c = c1 / c2;
	}
	c.Simplify();

	c_nume = c.get_nume();
	c_deno = c.get_deno();

	UpdateData(FALSE);
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值