第十五周 任务二

/* (程序头部注释开始) 
* 程序的版权和版本声明部分 
* Copyright (c) 2011, 烟台大学计算机学院学生  
* All rights reserved. 
* 文件名称:窗口练习 
 
* 作    者: 薛广晨                        
* 完成日期: 2012  年 05 月22 日 
* 版 本 号:       x1.0    
* 对任务及求解方法的描述部分 
* 输入描述:窗口化 (分数的加减乘除)
* 问题描述: 
* 程序头部的注释结束 
*/  

//头文件 CFrac.h

class CFraction
{
private:
	int nume;  // 分子
	int deno;  // 分母
 public:
	CFraction(int nu = 0, int de = 1) : nume(nu), deno(de){}   //构造函数,初始化用
	void output();

	CFraction operator+(CFraction &c1);
	CFraction operator-(CFraction &c1);
	CFraction operator*(CFraction &c1);
	CFraction operator/(CFraction &c1);

};

//CFrac.cpp

#include "stdafx.h"

#include "CFrac.h"

using namespace std;

CFraction CFraction :: operator+(CFraction &c1)
{ 
	CFraction c2;  
    c2.deno = deno * c1.deno;  
    c2.nume = nume * c1.deno + c1.nume * deno;
 
    c2.output();
 
    return c2;  
}  

CFraction CFraction :: operator-(CFraction &c1)
{  
	CFraction c2;  
    c2.deno = deno * c1.deno;  
    c2.nume = nume * c1.deno - c1.nume * deno; 
    c2.output(); 
    return c2;  
}  

CFraction CFraction :: operator*(CFraction &c1)
{  
	CFraction c2;  
    c2.deno = deno * c1.deno;  
    c2.nume = nume * c1.nume; 
    c2.output(); 
    return c2;  
}  

CFraction CFraction :: operator/(CFraction &c1)
{  
	CFraction c2;  
    c2.deno = deno * c1.nume;  
    c2.nume = nume * c1.deno;
    c2.output();
    return c2;  
}

void CFraction :: output()  {   int i;   if(nume >= 0)  {   if(deno < nume)i = deno;      else i = nume;      for(; i > 0; --i)      {    if(nume % i == 0 && deno % i == 0)       {     nume = nume / i;        deno = deno / i;        break;          }          }  }  else  {   nume = -nume;   if(deno < nume)i = deno;      else i = nume;      for(; i > 0; --i)      {    if(nume % i == 0 && deno % i == 0)       {     nume = nume / i;        deno = deno / i;        break;          }          }     nume = -nume;  }

}

//button按钮 void CcfractionDlg::OnBnClickedButton1() { // TODO: 在此添加控件通知处理程序代码 UpdateData();//将界面上的各控件输入的值“捕获”到与之关联的变量中 CFraction t1(m_nu1, m_du1); CFraction t2(m_nu2, m_de2); CFraction t3; if(m_a == "+") t3 = t1.operator+(t2); else if(m_a == "-") t3 = t1.operator-(t2); else if(m_a == "*") t3 = t1.operator*(t2); else if(m_a == "/") t3 = t1.operator/(t2); m_nu3 = t3.getnume(); m_de3 = t3.getdeno(); UpdateData(FALSE); }
 

 


上机感言: 费了好大的劲,终于做出来了。窗口看着就爽

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值