【PAT笔记】数学问题——分数的四则运算

分数的四则运算是从小学开始接触,运算规则和原理大家应该都很清楚了。我们现在要做的就是如何通过程序,让计算机来做分数的四则运算。

1 分数的表示

首先来表示一个分数,最简单的就是用假分数表示了,也就是无论分子比分母大还是比分母小,都保留原数。那么就可以通过设置一个结构体来存储这种只有分子和分母的分数了。

struct Fraction{
    int up,down;
};

2 分数的化简

在这里我采用《算法笔记》的定义方式来写。首先,我们要是Fraction变量满足三项规定,因此化简步骤也可以分为三步:

  1. 如果分母是负数,那么把分子up和分母down同时变为相反数;
  2. 如果分子up等于0,那么把分母down变为1;
  3. 约分:求出分子绝对值(思考为什么要加这里要加绝对值)和分母绝对值的最大公约数,然后令分子和分母同时除以d。

在正式给出分数化简算法代码之前,我对第三步做一个说明,也就是说,怎么求两个数的最大公约数和最小公倍数。

最大公约数 

在建立的数学理论之上(如果不能理解这两个数学术语的同学请自行百度或者Google),我们可以通过递归式来解决。两个递归的关键是:

  1. 递归式:gcd(a,b)=gcd(b,a%b);
  2. 递归边界:gcd(a,0)=a

很明显可以看出用了交换递归思想,于是可以得到下面的函数代码:

int gcd(int a,int b){
    if(b==0) return a;
    else return gcd(b,a%b);
}

 最小公倍数

最小公倍数在数学上的表达式为:a*b/gcd(a,b) ,即a和b的乘积除以a和b的最大公约数即为a和b的最小公倍数。

 

收回来,解决了约分这个步骤,那么我们开始来写分数简化的代码。

Fraction reduction(Fraction result){
    if(result.down<0){  //第一步,如果当分母为负数的时候
        result.up=-result.up;
        result.down=-result.down;
    }
    if(result.up==0){    //第二步,如果当分子为0的时候
        result.down=1;
    }
    else{
        int y=gcd(abs(result.up),abs(result.down));  //第三步,约分,其中gcd函数要体现写好
        result.up=result.up/y;
        result.down=result.down/y;
    }
    return result;
}

下面开始进行分数四则运算的思想和代码展示:

3 分数的加法

数学思想的公式体现:  result=\frac{f1.up*f2.down+f2.up*f1.dowm}{f1.down*f2.down}

那么就可以得到一下代码:

Fraction add(Fraction f1,Fraction f2){
    Fraction result;    //用result存储分数形式的值
    result.up=f1.up*f2.down+f2.up*f1.down;   
    result.down=f1.down*f2.down;    //分子和分母的计算
    return reduction(result);       //用reduction函数化简分数result
}

4 分数的减法

数学思想的公式体现:  result=\frac{f1.up*f2.down-f2.up*f1.dowm}{f1.down*f2.down}

那么就可以得到一下代码: 

Fraction minu(Fraction f1,Fraction f2){
    Fraction result;    //用result存储分数形式的值
    result.up=f1.up*f2.down-f2.up*f1.down;   
    result.down=f1.down*f2.down;    //分子和分母的计算
    return reduction(result);       //用reduction函数化简分数result
}

 5 分数的乘法

数学思想的公式体现:  result=\frac{f1.up*f2.up}{f1.down*f2.down}

那么就可以得到一下代码: 

Fraction multi(Fraction f1,Fraction f2){
    Fraction result;    //用result存储分数形式的值
    result.up=f1.up*f2.up;   
    result.down=f1.down*f2.down;    //分子和分母的计算
    return reduction(result);       //用reduction函数化简分数result
}

6 分数的除法

 数学思想的公式体现:  result=\frac{f1.up*f2.down}{f1.down*f2.up}

那么就可以得到一下代码: 

Fraction divide(Fraction f1,Fraction f2){
    Fraction result;    //用result存储分数形式的值
    result.up=f1.up*f2.down;   
    result.down=f1.down*f2.up;    //分子和分母的计算
    return reduction(result);       //用reduction函数化简分数result
}

总结

观察上面四个分数的四则运算可以看到,分数的四则运算模式很单一,每个函数执行的只有四行代码,其意义也很容易明白:定义一个Fraction型的result来存储运算后的值,对两个分数的分子和分母分别运算,最后用reduction函数化简返回result值。

纵观全局来看,我们要建立一个Fraction分数结构体,然后用约分函数(int gcd())、化简函数(Fraction reduction(Fraction result))以及四则运算函数。于是就可以构成整个算法的模型 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_之桐_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值