第十五周实验报告(二)

分数计算器实现
FractionDlg.cpp

void CmyfractionDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
	if ((nID & 0xFFF0) == IDM_ABOUTBOX)
	{
		CAboutDlg dlgAbout;
		dlgAbout.DoModal();
	}
	else
	{
		CDialog::OnSysCommand(nID, lParam);
	}
}

// 如果向对话框添加最小化按钮,则需要下面的代码
//  来绘制该图标。对于使用文档/视图模型的 MFC 应用程序,
//  这将由框架自动完成。

void CmyfractionDlg::OnPaint()
{
	if (IsIconic())
	{
		CPaintDC dc(this); // 用于绘制的设备上下文

		SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);

		// 使图标在工作区矩形中居中
		int cxIcon = GetSystemMetrics(SM_CXICON);
		int cyIcon = GetSystemMetrics(SM_CYICON);
		CRect rect;
		GetClientRect(&rect);
		int x = (rect.Width() - cxIcon + 1) / 2;
		int y = (rect.Height() - cyIcon + 1) / 2;

		// 绘制图标
		dc.DrawIcon(x, y, m_hIcon);
	}
	else
	{
		CDialog::OnPaint();
	}
}

//当用户拖动最小化窗口时系统调用此函数取得光标
//显示。
HCURSOR CmyfractionDlg::OnQueryDragIcon()
{
	return static_cast<HCURSOR>(m_hIcon);
}


void CmyfractionDlg::OnBnClickedButton1()
{
	// TODO: 在此添加控件通知处理程序代码
	UpdateData();
	if(symbol == '+')
	{
	    if(a_deno == b_deno)
	    {
		    c_mole = a_mole + b_mole;
		    c_deno = a_deno;
	    }
	    else
	    {
		    c_mole = a_mole * b_deno + a_deno * b_mole;
		    c_deno = a_deno * b_deno;
	    }
	}
	else if(symbol == '-')
	{
	    if(a_deno == b_deno)
	    {
		    c_mole = a_mole - b_mole;
		    c_deno = a_deno;
	    }
	    else
	    {
		    c_mole = a_mole * b_deno - a_deno * b_mole;
		    c_deno = a_deno * b_deno;
	    }
	}
	else if(symbol == '*')
	{
		c_mole = a_mole * b_mole;
		c_deno = a_deno * b_deno;
	}
	else if(symbol == '/')
	{
		c_mole = a_mole * b_deno;
		c_deno = a_deno * b_mole;
	}
	Fraction fc(c_mole, c_deno);
	fc.Simplify();
	c_mole = fc.get_mole();
	c_deno = fc.get_deno();
	UpdateData(FALSE);
}

Fraction.hclass Fraction{public:Fraction(){mole = 1; deno = 1;}Fraction(int x, int y){mole = x; deno = y;}int get_mole();int get_deno();void Simplify();private:int mole;int deno;};


Fraction.cpp

#include "stdafx.h"
#include "Fraction.h"

int Fraction::get_mole()
{
	return mole;
}
int Fraction::get_deno()
{
	return deno;
}

void Fraction::Simplify()  
{  
    int m,n,r;  
    m = abs(deno);  
    n = abs(mole);  
    while(r = m % n)  // 求m,n的最大公约数   
    {  
        m = n;  
        n = r;  
    }  
    deno /= n;     // 化简   
    mole /= n;  
    if (deno < 0)  // 将分母转化为正数   
    {  
        deno = -deno;  
        mole = -mole;  
    }  
} 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值